首页 > 运维 > linux运维 > 正文

移植speexdsp到OpenHarmony标准系统⑥

看不見的法師
发布: 2025-07-20 10:46:02
原创
878人浏览过

九、准备好上传speexdsp至openharmony仓库。

完成移植后,首先将代码上传到sig仓库中的contest仓库。

移植speexdsp到OpenHarmony标准系统⑥

上传的内容包括:

  • 原生库代码(除了涉及需要修改原生库代码的部分,其他都不能上传,例如编译途中生成的中间文件)
  • BUILD.gn
  • README.OpenSource
  • 库对外导出的所有API接口 export_api.txt
  • 测试过的API接口 tested_api.txt
  • 功能测试文档:三方库_test_function.md,内容至少包含罗列出库所有的功能,已测试过的功能,原生库测试逻辑的分析
  • 原生库分析文档:三方库_analyse.md
  • 文档命名不要使用中文,如果涉及到编码问题的话,到时候会出现乱码,一般建议不用中文命名!!!

提供OAT.xml文件进行开源扫描。

移植speexdsp到OpenHarmony标准系统⑥

工具使用编译构建:

在Linux上安装好Java和Maven后,下载OAT工具源码,执行mvn package完成构建。

移植speexdsp到OpenHarmony标准系统⑥

编译构建成功后:

移植speexdsp到OpenHarmony标准系统⑥

在父目录下添加OAT.xml,内容如下:

<?xml version="1.0" encoding="UTF-8"?>
<configuration>
    <oatconfig>
        <licensefile>COPYING</licensefile>
        <policylist>
            <policy desc="" name="projectPolicy">
                <policyitem desc="" filefilter="defaultPolicyFilter" group="defaultGroup" name="*" path=".*" rule="may" type="license"></policyitem>
            </policy>
        </policylist>
        <filefilterlist>
            <filefilter desc="Files not to check" name="defaultFilter">
                <filteritem desc="原生库文件" name=".*" type="filepath"></filteritem>
            </filefilter>
            <filefilter desc="Filters for compatibility,license header policies" name="defaultPolicyFilter">
                <filteritem desc="原生库代码" name=".*" type="filepath"></filteritem>
            </filefilter>
            <filefilter desc="Filters for copyright header policies" name="copyrightPolicyFilter">
                <filteritem desc="原生库代码" name=".*" type="filepath"></filteritem>
            </filefilter>
            <filefilter desc="Filters for LICENSE file policies" name="licenseFileNamePolicyFilter"></filefilter>
            <filefilter desc="Filters for README file policies" name="readmeFileNamePolicyFilter"></filefilter>
            <filefilter desc="Filters for README.OpenSource file policies" name="readmeOpenSourcefileNamePolicyFilter"></filefilter>
            <filefilter desc="Filters for binary file policies" name="binaryFileTypePolicyFilter"></filefilter>
        </filefilterlist>
        <licensematcherlist></licensematcherlist>
    </oatconfig>
</configuration>
登录后复制

在speexdsp根目录下新建空白的OAT_report.text文件,执行命令:

java -jar ohos_ossaudittool-1.0.jar -s src_dir -r report_file -n selfcheck
登录后复制

ohos_ossaudittool-1.0.jar 工具包名,需要带实际路径

  • -s 指定需要检查的代码目录,src_dir 改成要检查的项目路径
  • -r 指定报告输出文件的路径,检查完成后可查看此文件中列出的问题,按指导文档修复report_file
  • -n 检查任务的名称,任意指定,本地检查使用不上

例如笔者执行的语句为:

sudo java -Dfile.encoding=UTF-8 -jar /home/jiajiahao/Desktop/tools_oat-master/target/ohos_ossaudittool-1.0.jar -s /home/jiajiahao/Desktop/gitee_speexdsp -r /home/jiajiahao/Desktop/gitee_speexdsp/OAT_report.text -n nameOfRepo
登录后复制

扫描结果执行完上述命令后,OAT_report.text生成内容如下:

移植speexdsp到OpenHarmony标准系统⑥

同时在speexdsp父目录下生成log文件夹。

移植speexdsp到OpenHarmony标准系统⑥

LicenseFile.txt位于OAT工具运行目录的log目录下,此文件记录扫描目录下所有疑似许可证的文件。

智标领航
智标领航

专注招投标业务流程的AI助手,智能、高效、精准、易用!

智标领航117
查看详情 智标领航

提供README.OpenSource文件,README.OpenSource的格式如下:

[
    {
        "Name": "", ## 库名
        "License": "", ## 开源协议
        "License File": "", ## 开源文件,一般开源项目都会自带该文件
        "Version Number": "", ## 库的版本
        "Owner": "", ## 作者
        "Upstream URL": "", ## 开源库的地址
        "Description": "" ## 库的描述
    }
]
登录后复制

speexdsp的README.OpenSource文件如下:

[
    {
        "Name": "speexdsp",
        "License": "BSD-3-Clause",
        "License File": "COPYING",
        "Version Number": "1.2.1",
        "Owner": "2692032597@qq.com",
        "Upstream URL": "https://speex.org/",
        "Description": "Speexdsp is a speech processing library that goes along with the Speex codec"
    }
]
登录后复制

提供库的分析文档,三方库分析文档如下:

一、确定库实现方式
例如:C/C++/JS/JAVA
二.依赖分析
例如:当前库依赖其他三方库,如下
1)库名1,库仓库地址
2)库名2,库仓库地址
三、license以及版权
例如:一般在license文件或者COPYING中,Apache License V2.0
四、最新一次版本xx年xx月xx日,版本号xxx
五、功能点分析(罗列出该库所支持的功能)
六、代码规模(统计库代码总行数,包括.h/.hpp/.c/.cpp/.cc 等代码相关文件)
登录后复制

提供功能测试文档,文档中需罗列出:

  • 库所有的功能
  • 已测试过的功能
  • 原生库测试逻辑的分析

提供导出的API接口列表:

  1. 导出库对外暴露的所有API接口的列表
  2. 导出库对外暴露的已测试API接口的列表

十、上传speexdsp至OpenHarmony仓库

配置个人信息,打开git bash,依次输入以下命令:

git config --global user.name "xxxx"   (配置用户名,xxxx为账号用户名,即个人空间地址)
git config --global user.email "xxxxxx@xxx"  (gitee 账号邮箱与签署DCO 的邮箱保持一致即可)
git config --list         (查看配置情况)
git config --global credential.helper store (解决每次git pull都要输入账号信息的问题)
登录后复制

克隆仓库内容到本地,到个人账号点击并进入contest仓库,fork该仓库:

移植speexdsp到OpenHarmony标准系统⑥

进入到clone界面,复制clone的链接地址。

移植speexdsp到OpenHarmony标准系统⑥

执行如下语句:

git clone https://gitee.com/xxxxx/contest.git --depth=1
登录后复制

--depth=1意思是只clone当前仓库最新版本,省去一些历史log,避免仓库历史记录过于庞大花费太多clone时间。clone完毕之后,即可在本地目录下看到这个clone的仓库。本地目录所在位置是根据git bash的位置决定的,比如在桌面启动git bash,则clone的仓库会出现在桌面。

利用git lfs机制添加特殊文件,提交三方库时候,文档中有PDF文件时就需要使用利用git lfs机制。

git lfs track xxx/xxx.pdf  // 声明该特殊文件到git lfs机制
登录后复制
git add .gitattributes // 添加配置文件
登录后复制
git add xxx/xxx.pdf // 添加具体特殊文件到暂存区中
登录后复制
git lfs ls-files  // 确认相关test_lfs.a 文件是否已经添加到lfs 机制中。
登录后复制
git  add *   //将变更文件加入到暂存区
登录后复制
git commit -s -m  "add xxxxxxxx"  //将暂存区内容签名并提交到本地
登录后复制

-s是签名表明这次提交者签名(signoff),-m是对此次提交行为进行备注。

git commit --amend
登录后复制

推送本地修改到账号仓库,现在需要将本地仓库的修改内容推送到gitee上fork后的个人仓库,使用git push命令来完成这个动作。

git push origin master
登录后复制

origin指的是自己的仓库对应的原始远程服务器地址;master标识的是想要提交的分支。可以使用 git remote -v查看配置的远程服务器;git branch -a查看所有的分支。

写在最后,如果你觉得这篇内容对你还蛮有帮助,我想邀请你帮我三个小忙:

  • 点赞,转发,有你们的 『点赞和评论』,才是我创造的动力;
  • 关注小编,同时可以期待后续文章ing?,不定期分享原创知识;
  • 想要获取更多完整鸿蒙最新学习知识点,可关注B站:码牛课堂鸿蒙开发;

以上就是移植speexdsp到OpenHarmony标准系统⑥的详细内容,更多请关注php中文网其它相关文章!

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号