0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看威廉希尔官方网站 视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

如何通过SIG进行开源贡献

OpenAtom OpenHarmony 来源:OpenAtom OpenHarmony 作者:OpenAtom OpenHarmony 2022-07-23 10:15 次阅读

如何优雅地参与开源贡献,向顶级开源项目提交 PR(Pull Request)。战“码”先锋直播间第八期围绕“OpenAtom OpenHarmony(以下简称“OpenHarmony”)开源贡献”话题,邀请了深圳开鸿数字产业发展有限公司(以下简称“深开鸿”)资深OS框架开发工程师巴延兴为大家带来《如何多方位参与OpenHarmony开源贡献》主题分享。

本次分享主要介绍了巴延兴带领深开鸿开源共建团队在主导/共建16个SIG、贡献超过50万行代码的OpenHarmony “战码”经验,在根威廉希尔官方网站 、垂直领域、生态扩展等多方位参与开源贡献的实践与思考,以及辅助工具SIG和内核SIG两大板块的贡献方式、价值与用途,希望有更多开发者参与开源共建。

参与战“码”先锋,PR征集令!感兴趣的开发者可以在Gitee的OpenHarmony代码仓提交PR参与活动,和全球开发者同台竞技,比拼技艺,为OpenHarmony生态建设贡献力量。

如何通过SIG进行开源贡献

什么是SIG? SIG全称Special Interest Group,即特别兴趣小组,专注一个特定的威廉希尔官方网站 领域,负责该领域威廉希尔官方网站 竞争力分析和关键威廉希尔官方网站 识别及决策,引领威廉希尔官方网站 演进的方向,也是共建单位及个人开发者进行开源贡献的基本单位。 通过SIG组参与开源共建的两种方式 一、参与到已有SIG的共建
参与者需要注册自己的官方账号,签订协议后,才能通过认领SIG leader发布的需求来承接共建任务。领完需求后是标准的开发过程,包括需求分析、功能设计、代码开发、功能测试、功能交付等步骤;任务开发完成后,需要提交PR,将代码、文档等提交到社区,完成最终的开源贡献。

二、主导SIG组

1、成立SIG

选取共建威廉希尔官方网站 领域并给出规划 → 向PMC例会提交议题并通过评审 → 通过架构SIG例会评估后建立新的代码仓。

2、孵化SIG

启动需求澄清、特性梳理方案设计、代码开发、单元测试、功能测试等流程,完成SIG项目开发 → 对照Check List,完成法务、门禁、OAT等问题自检。

3、毕业SIG

向架构SIG申请新SIG毕业 → 向QA SIG会申请新SIG准出 → 仓库owner移仓。

70165f6c-09bf-11ed-ba43-dac502259ad0.png

辅助工具SIG实践经验分享

成立辅助工具SIG组的宗旨是“降低重复劳动,提高工作效率,让专业的人做专业的事”。NAPI框架代码生成工具、IDL转换工具和开机动画工具都是围绕着这个宗旨开发而成的。

一、NAPI框架代码生成工具

NAPI是标准设备上的JS API实现方式,实现了JS语言到框架C++层的调用,在OpenHarmony系统中,APP调用是调用JS语言的接口函数,最终具体功能是用C++语言来实现。

NAPI存在三个开发痛点需要解决:

1、NAPI框架代码的重复率高:面对不同的JS接口,开发者要实现相似度高的框架代码。

2、NAPI框架的学习成本高:框架机制涉及JavaScript、C++语言,以及编译脚本工具。

3、NAPI 需求量大:OpenHarmony系统功能均是通过NAPI接口体现,目前已经支持1万多个NAPI接口。

针对以上三个痛点,NAPI框架代码生成工具将C++ 、JavaScript接口类型转换等代码抽取公共模块,并且自动生成编译脚本。开发者使用工具自动生成NAPI框架代码,只需实现业务代码调用即可,避免了大量重复的工作。

7051aa5e-09bf-11ed-ba43-dac502259ad0.png

二、IDL转换工具

OpenHarmony使用的是HDF驱动框架,驱动相应的硬件信息需要IDL文件来描述。

IDL存在两大开发痛点需要解决:

1 、HDI开发难度大:HDI开发者比较熟悉C语言,习惯在.h文件中定义HDI接口,而对于IDL文件结构、语法并不是很熟悉,学习曲线相对较长。

2、HDI工作量大:HDI接口是驱动对外提供服务的必要条件,各个子系统均涉及,故HDI工作量较大。

针对以上痛点,深开鸿设计的IDL转换工具将开发者熟悉的.h文件自动转换为idl文件,开发者只需要在头文件中定义自己的接口即可,工具自动实现.h头文件到IDL文件转换,开发者不需要关心IDL语法,大大降低工作量。

70632964-09bf-11ed-ba43-dac502259ad0.png

三、开机动画工具

开机动画工具是我们早期针对OpenHarmony2.0版本存在的问题做的一个辅助工具。

OpenHarmony2.0版本在开机动画方面有两个问题:

1、OpenHarmony2.0版本开机动画只支持raw文件,不利于开发者在发行版和定制版进行直接展现。

2、因为产品的形态不一,对于不同的产品,其开机动画的需求也是不同。

通过开机动画辅助工具使以上两个问题得到了更好地解决:

1、开机动画工具支持图片集或者 mp4等多种文件生成开机动画,且支持设置开机动画的分辨率等操作,更加方便开机动画的制作。

2、做到一键生成开机动画文件,并且支持在 windows平台上查看其效果,不需要每次都去烧录到开发板上,大大降低了演示的工作量。

708d0360-09bf-11ed-ba43-dac502259ad0.png

四、辅助工具SIG共建方向

目前深开鸿主导的辅助工具SIG组主要提供给开发者文档资料、测试用例和工具开发3个共建方向。

如果你擅长文档编撰,那么可以参与到社区的文档贡献,撰写文档可以不需要有很强的开发能力。

如果你是测试人员,擅长自动化测试,那么通过测试用例也可以参与到社区的建设。

另外也欢迎各位开发者参与到各种工具的建设中来。SIG组的工具可以是独立的工具,也可以通过插件的方式集成到IDE开发软件中。

73dbffc6-09bf-11ed-ba43-dac502259ad0.png

五、参与辅助工具SIG贡献的具体方式

1、提交问题单。无论是文档的bug、测试用例的bug、还是代码的bug,提交了问题单就是对社区做了贡献,那么辅助工具SIG组如何提交问题单呢?

首先找到对应的仓库并登录,例如https://gitee.com/openharmony/napi_generator/issues。

提交过程中要注意格式要求,必须写清楚提单过程中问题出现的条件,预期的结果和错误的结果,问题的定位信息等,有了这些信息后,领取这个问题单的开发也方便定位问题。

7406918c-09bf-11ed-ba43-dac502259ad0.png

登录找到想要认领的问题单的页面,在评论中表达出想要承接这个需求的意愿,SIG的负责人会定期跟踪这些问题单并做出答复。

742916f8-09bf-11ed-ba43-dac502259ad0.png

2、认领需求后进行开发流程

领到一个需求后要进行正常的开发,核心分为以下6步:

①通常开发者已经配置好配置码云账号、个人邮箱和签署DCO(签署DCO主要是保证贡献者原创),有了这些前置工作以后,我们可以操作代码仓库进行需求的开发。

②Fork代码到私仓。

③克隆fork出来的仓库到自己的主机上。

④在本地开发代码开发和功能验证。

⑤开发完毕后向官方原始仓提交Pull Request,提交代码后会触发门禁等常规检查。

⑥如果这个sig组是你自己主导的,那么作为Committer,需要评审别人提交的代码,如果只是参与共建,提交完代码通过门禁就完成任务。

内核SIG参与共建经验

关于深开鸿内核SIG共建经验,下面将以文件系统的优化为实例向大家分享具体的贡献过程。

内核共建的方向比较多,体系架构有各个硬件平台的移植,内核模块中功耗管理、时间管理、任务调度、中断管理、文件系统、三方库相关的内核shell命令移植,目前深开鸿主要在文件系统和第三方库方面做社区共建。深开鸿希望将来展开更多方向的优化工作,并向外提供具体场景下内核系统移植方案。

74528498-09bf-11ed-ba43-dac502259ad0.png

littlefs文件系统的共建过程:

1、了解社区需求,社区目前对littlefs文件系统随机读写的速度不满意。

2、了解到社区文件系统对随机读写需求的前提下,对littlefs随机读写IO性能瓶颈进行分析,找到能优化的代码点,采用了“以空间换时间”的思路。

3、采用逐步优化的思路,明确方案后和社区负责人沟通,得到了社区负责人认可后,展开具体的代码工作。

747c930a-09bf-11ed-ba43-dac502259ad0.png

由于文件系统优化是一个比较复杂的过程,下面分享了一套社区共建流程。

1、从社区认领需求后,通过微信群的方式和社区负责人沟通并澄清需求。

2、从威廉希尔官方网站 上分析需求并制定优化方案,再次和社区负责人沟通,做方案讨论并得到认可。

3、具体任务开发,包括任务拆解、编码实现、测试,最后提交PR。

74c89ad4-09bf-11ed-ba43-dac502259ad0.png

针对littlefs文件系统优化过程中修改涉及到的相关文件,包括littlefs文件代码,也就是点c和点h文件;也有编译相关的文件,即.gn文件gni文件,之所以修改编译相关的文件是为了测试littlefs的优化后的代码,我们团队增加了相关的测试用例,这些测试用例会调用内核文件系统的API,涉及到这些编译相关的文件。

74efc172-09bf-11ed-ba43-dac502259ad0.png

littlefs第三方库代码完成后提交到社区的过程

1、littlefs第三方库repository路径,并fork到用户仓库。

2、git clone用户仓到本地。

3、提交修改到用户仓。

4、点击提交PR。

5、填写PR单,PR单页需要按照既定模板填写,写清楚原始需求,如何解决这个问题,怎么解决这个问题以及具体修改点。

6、在评论中添加“start build”点亮PR。这里有一个特别注意的点,需要在评论中是手动填写“start build”这2个英文单词,目的是触发后续的门禁检测。这是OpenHarmony社区比较特别的一点,其它开源项目中所没有的。

753a09da-09bf-11ed-ba43-dac502259ad0.png

756202b4-09bf-11ed-ba43-dac502259ad0.png

757e0b80-09bf-11ed-ba43-dac502259ad0.png

欢迎感兴趣的开发者多方位参与OpenHarmony开源贡献,成为OpenHarmony Contributor,也欢迎各位提出宝贵的意见,为OpenHarmony贡献一份力量。

参与战“码”先锋,PR 征集令!在Gitee的OpenHarmony代码仓提交PR参与活动,和全球的开发者一起共建OpenHarmony的繁荣生态!

文章中涉及的链接汇总:

NAPI框架代码生成工具代码仓地址:

https://gitee.com/openharmony/napi_generator

IDL转换工具代码仓地址:

https://gitee.com/openharmony/drivers_hdf_core/tree/master/framework/tools/idl-gen

开机动画工具代码仓地址:

https://gitee.com/openharmony/graphic_graphic_2d/tree/master/frameworks/bootanimation/data/bootanimation_tool


审核编辑 :李倩


声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 开源
    +关注

    关注

    3

    文章

    3355

    浏览量

    42511
  • 代码
    +关注

    关注

    30

    文章

    4789

    浏览量

    68640

原文标题:30分钟成为Contributor|如何多方位参与OpenHarmony开源贡献?

文章出处:【微信号:gh_e4f28cfa3159,微信公众号:OpenAtom OpenHarmony】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    CCF开源创新大赛决赛结果发布!OpenHarmony应用开发赛道尽展风采

    经过数月的激烈比拼与项目展示,第七届CCF开源创新大赛决赛结果揭榜!其中,深开鸿的“OpenHarmony应用开发-开源项目贡献赛”赛道星光熠熠,表现突出。在此,发布颁奖典礼通知,让我们共同见证
    的头像 发表于 11-07 08:07 265次阅读
    CCF<b class='flag-5'>开源</b>创新大赛决赛结果发布!OpenHarmony应用开发赛道尽展风采

    星光璀璨,聆听 OpenHarmony 贡献者之声

    在第三届开放原子开源基金会OpenHarmony威廉希尔官方网站 大会上, 我们满怀敬意地对取得优秀成果的星光OpenHarmony威廉希尔官方网站 俱乐部、星光导师、星光贡献者、星光活动进行了致谢。 他们不仅是威廉希尔官方网站 的探索者
    发表于 10-28 17:09

    CC256x蓝牙SIG认证应用说明

    电子发烧友网站提供《CC256x蓝牙SIG认证应用说明.pdf》资料免费下载
    发表于 09-11 09:41 0次下载
    CC256x蓝牙<b class='flag-5'>SIG</b>认证应用说明

    迅龙软件OrangePi 5 Plus顺利通过开放原子开源基金会XTS认证

    迅龙软件的热销产品OrangePi5Plus最近传来好消息。其顺利通过开放原子开源基金会XTS认证,并获颁OpenHarmony生态产品兼容性证书。开放原子开源基金会是在民政部注册的致力于开源
    的头像 发表于 09-09 15:36 543次阅读
    迅龙软件OrangePi 5 Plus顺利<b class='flag-5'>通过</b>开放原子<b class='flag-5'>开源</b>基金会XTS认证

    英特尔中国开源威廉希尔官方网站 委员会成立一周年

    开源已成为威廉希尔官方网站 和产业生态发展的重要趋势。英特尔秉持着开放、选择、信任的原则贯彻开源,并在社区、开源项目、开发者等方面贡献力量,带动更多参与者共同实现生态繁荣。2023年2月,英特尔中国
    的头像 发表于 08-16 15:35 469次阅读

    10万奖金池!CCF开源创新大赛-OpenHarmony应用开发大赛,等你来战!

    生态建设的高质量发展。深开鸿发布“OpenHarmony应用开发-开源项目贡献赛”赛道,旨在通过开发开源鸿蒙北向应用、扩展开源鸿蒙开发工具链
    的头像 发表于 07-17 08:33 698次阅读
    10万奖金池!CCF<b class='flag-5'>开源</b>创新大赛-OpenHarmony应用开发大赛,等你来战!

    新思科技宣布出售SIG业务

    新思科技(Synopsys)近日宣布了一个引人注目的交易计划,已经与由Clearlake Capital和Francisco Partners领头的私募股权财团达成最终协议,将其旗下的SIG(软件
    的头像 发表于 05-08 10:35 504次阅读

    新思科技将以超20亿美元出售SIG部门

    和Francisco Partners共同牵头的财团正在与新思科技就SIG部门的收购进行深入谈判,预计交易金额将超过20亿美元。
    的头像 发表于 05-07 09:52 458次阅读

    迅龙软件加入开放原子开源基金会和OpenHarmony 项目,共建开源新生态

    业的应用,提高开源威廉希尔官方网站 对数字化转型的价值贡献。持续深耕开源领域赋能千行百业在国家战略层面,“开源”首次被明确列入国民经济和社会发展五年规划纲要,“十四五”规划提到要“支持数字
    的头像 发表于 04-30 17:50 1044次阅读
    迅龙软件加入开放原子<b class='flag-5'>开源</b>基金会和OpenHarmony 项目,共建<b class='flag-5'>开源</b>新生态

    深开鸿升为OpenHarmony项目群A类捐赠人,引领开源生态新篇章!

    近日,深开鸿作为OpenHarmony核心共建单位、OpenHarmony生态委员会委员单位、OpenHarmony代码Top10贡献单位,通过了开放原子开源基金会OpenHarmony工作委员会
    的头像 发表于 04-18 08:33 825次阅读
    深开鸿升为OpenHarmony项目群A类捐赠人,引领<b class='flag-5'>开源</b>生态新篇章!

    模数转换器 SIG5531A 国产平替 CS5531AS

    板子拿来,换个芯片,性能更好。MCU 不用改 c code。 SIG5531A/SIG5532A/SIG5533A/SIG5534A 1.6SPS to 3840SPS 16-bi
    发表于 03-11 12:56

    HDMI论坛出手,AMD开源HDMI 2.1驱动被拒

    电子发烧友网报道(文/周凯扬)作为一直在为开源社区不断贡献的科技大厂,AMD在Linux上贡献了无数代码,尤其是在图形开源驱动,其贡献的代码
    的头像 发表于 03-05 00:10 2892次阅读

    开放原子开源基金会新增捐赠人(2023年12月)

    人才交流中心 成为基金会开源贡献人 •  中国电子威廉希尔官方网站 标准化研究院 成为基金会开源贡献人 • 工业和信息化部电子第五研究所 成为基金会开源
    的头像 发表于 01-15 20:50 1541次阅读
    开放原子<b class='flag-5'>开源</b>基金会新增捐赠人(2023年12月)

    有“源”同行,感谢肯定!| 来自开放原子开源基金会的年度感谢信!

    岁末年关,一封封来自开放原子开源基金会、OpenHarmony项目群工作委员会各工作组的感谢信纷至沓来,字里行间是对深开鸿助力开源事业发展、尤其是在OpenHarmony项目生态建设方面突出贡献
    的头像 发表于 01-05 16:49 621次阅读
    有“源”同行,感谢肯定!| 来自开放原子<b class='flag-5'>开源</b>基金会的年度感谢信!

    开源鸿蒙赋能电力新能源发展

    随着科技的不断发展,能源行业也在不断地进行创新和升级。而在这个变革的过程中,开源鸿蒙系统的应用无疑为能源行业带来了新的机遇和挑战。九联科技作为一家专注于开源鸿蒙系统的科技公司,一直致力于将这一先进的威廉希尔官方网站 应用于实际生产中,为能源行
    的头像 发表于 01-04 10:27 922次阅读
    <b class='flag-5'>开源</b>鸿蒙赋能电力新能源发展