啃论文俱乐部——移植speexdsp到OpenHarmony标准系统⑥ 原创 精华
- 大家好!我来自南京,在OpenHarmony成长计划啃论文俱乐部,与
华为、软通动力、润和软件、拓维信息、深开鸿
等公司一起,学习和研究操作系统技术
从今年1月11日加入OpenHarmony俱乐部已经有接近8个月时间了。笔者一直在思考啃论文给我带来了些什么,通过啃论文能为OpenHarmony做些什么。笔者利用大二升大三暑假两个月时间移植了Speexdsp这个三方库到OpenHarmony标准系统,而关于前面的问题我似乎找到了答案,现将啃论文和三方库移植分享经验如下:
由于想要分享的内容较多,为避免读者姥爷们失去看下去的耐心,分享将以连载的方式进行。
下期预告:移植Speedsp到OHOS——VoIP语音质量适配应用层机制研究综述
往期回顾:
啃论文俱乐部——移植speexdsp到OpenHarmony标准系统①
啃论文俱乐部——移植speexdsp到OpenHarmony标准系统②
啃论文俱乐部——移植speexdsp到OpenHarmony标准系统③
啃论文俱乐部——移植speexdsp到OpenHarmony标准系统④
啃论文俱乐部——移植speexdsp到OpenHarmony标准系统⑤
本期为移植speexdsp到OpenHarmony标准系统
的第⑥期,主要内容如下:
目录
speexdsp移植后已提交至openhamrony sig仓库:https://gitee.com/openharmony-sig/contest/tree/master/2022_OpenHarmony_thirdparty/speexdsp
九、准备好上传speexdsp至OpenHarmony仓库。
移植完成后,先将代码上传至sig仓中的contest仓
sig仓库是TPC仓库的孵化仓。代码先上sig仓,到时会直接平移到tpc仓。
上传的内容包括:
- 原生库代码
- (除了涉及需要修改原生库代码的部分,其他都不能上传,例如编译途中生成的中间文件)
- BUILD.gn
- README.Opensource
- 库对外导出的所有api接口export_api.txt
- 测试过的api接口tested_api.txt
- 功能测试文档: 三方库_test_function.md
- 内容至少包含罗列出库所有的功能,已测试过的功能,原生库测试逻辑的分析
- 原生库分析文档: 三方库_analyse.md
文档命名不要用中文,如果涉及到编码问题的话,到时候会出现乱码,一般建议不用中文命名!!!
提供OAT.xml文件
OAT开源扫描
- OAT(OSS Audit Tool)是OpenHarmony社区的自动化开源审视工具,用于帮助开发人员基于自定义的规则自动扫描开源仓代码,识别不符合预定规则的代码并输出扫描报告。
- OAT下载地址:https://gitee.com/openharmony-sig/tools_oat
工具使用
编译构建:
- 在linux上安装好java和Maven后,下载OAT工具源码,执行mvn package完成构建。
- 编译构建成功
在父目录下添加OAT.xml,内容如下:
在speexdsp根目录下新建空白的OAT_report.text文件,执行命令:
-
ohos_ossaudittool-1.0.jar 工具包名,需要带实际路径
-
-s 指定需要检查的代码目录,src_dir 改成要检查的项目路径
-
-r 指定报告输出文件的路径,检查完成后可查看此文件中列出的问题,按指导文档修复
-
report_file
-
-n 检查任务的名称,任意指定,本地检查使用不上。
例如笔者执行的语句为:
扫描结果
执行完上述命令后,OAT_report.text生成内容如下:
同时在speexdsp父目录下生成log文件夹
- LicenseFile.txt位于OAT工具运行目录的log目录下,此文件记录扫描目录下所有疑似许可证的文件
原生库通过make或者cmake时生成的一些配置文件。如比较通用的config.h配置文件,config.h文件为原生库生成文件,原则上也不做修改,为了避免文件上仓进行代码扫码,可以将文件文件修改后缀名(config.h.in)。相关文档中需要将配置文件使用方法说明。
提供README.OpenSource文件
README.Opensource的格式如下:
speexdsp的README.OpenSource文件如下:
提供库的分析文档
三方库分析文档如下:
提供功能测试文档
文档中需罗列出
- 库所有的功能
- 已测试过的功能
- 原生库测试逻辑的分析
提供导出的api接口列表
1、 导出库对外暴露的所有api接口的列表
2、导出库对外暴露的已测试api接口的列表
十、上传speexdsp至OpenHarmony仓库
配置个人信息
打开git bash,依次输入以下命令:
克隆仓库内容到本地
到个人账号点击并进入contest仓库, fork该仓库:
进入到clone界面,复制clone的链接地址。
执行如下语句:
-
–depth=1意思是只clone当前仓库最新版本,省去一些历史log,避免仓库历史记录过于庞大花费太多clone时间。
-
clone完毕之后,即可在本地目录下看到这个clone的仓库。本地目录所在位置是根据git bash的位置决定的,比如在桌面启动git bash,则clone的仓库会出现在桌面。
利用git lfs机制添加特殊文件
提交三方库时候,文档中有PDF文件时就需要使用利用git lfs机制
- -s是签名表明这次提交者签名(signoff)
- -m是对此次提交行为进行备注.
推送本地修改到账号仓库
现在需要将本地仓库的修改内容推送到gitee上fork后的个人仓库,使用git push命令来完成这个动作。
- origin指的是自己的仓库对应的原始远程服务器地址;
- master标识的是想要提交的分支。
- 可以使用 git remote -v查看配置的远程服务器;
- git branch -a查看所有的分支。
进入自己的账号下面,查看这个仓库,发现已经发生了变化。从个人账号仓库下向官方仓库下提交PR。
进入个人账号的该仓库下,点击增加PR即可开始提交PR。
提交pr时,push的文件超过100个文件,在pr页面只显示100个。
佩服楼主源源不断的创作动力
把自己了解的东西分享出来,为了吸引更多开发者。
必须为楼主点赞
sig仓平移到tpc仓只要等一段时间就可以了吗?
这个工作由ohos官方的人完成,可以这么理解