mirror of
https://github.com/RubyMetric/chsrc
synced 2025-12-26 12:41:59 +08:00
3.0 KiB
3.0 KiB
Write A Recipe Even If You Don't Know C
介绍
chsrc 不仅是一个命令行工具,同时也是一个换源框架,它甚至使你能够在不了解C语言的情况下编写出新的换源方法(recipe)。
我鼓励你为新的软件添加换源支持,因为通过 chsrc 这将非常简单,你的贡献也将非常有价值。
- 本项目采用
GPLv3+协议,是真正的自由软件,而非仅仅是开源软件 - 代码规范灵活遵循
GNU标准(若标准干扰了可维护性,则并不采纳) - 高度模块化,目录结构清晰易懂
- 易于将
shell脚本转换为等价的recipe - 已有大量
recipe可提供参考 - 提供了 recipe template 供直接使用
成功案例: Armbian
贡献指导
若有任何问题,可在 GitHub discussions 中询问和讨论
基本概念
-
target: 所要换源的目标 -
category: 是target category的缩写,即target所属的类别,可以是 编程语言,操作系统,软件 三类之一- 在目录中,三者分别为
lang,os,ware - 在代码中,三者前缀分别为
pl,os,wr
- 在目录中,三者分别为
-
mirror: 是mirror site的缩写,指镜像站,如清华大学开源软件镜像站 -
source: 该target所能换的具体的源,由mirror提供服务 -
recipe: 是为一个target定义的具体换源方法,请参考src目录中的recipe目录 -
feature: 一个target可以支持的功能,比如能否重置回默认上游源等
编写recipe步骤
-
务必使用
dev分支 -
在
recipe目录中根据类别添加新文件,该文件可基于其它recipe或 recipe template -
最好的参照物是 ruby.c recipe
-
在各大镜像站寻找可用源;可以额外补充镜像站
-
可以使用
chsrc.h中暴露出的任何chsrc_开头的函数或宏 -
在
menu.c中添加用户可以使用的target别名 -
构建并运行
chsrc set <target>测试,若无问题可提交 Pull Request
不要制造UFO
开发准则:
- Convention over Configuration
- NO UFO 原则: 不要乱丢文件到$HOME等目录,尤其是使用各种隐晦的文件名
chsrc 主程序不提供配置文件,不提供数据文件,干净无污染。那么在实现 recipe 的时候,除了备份文件外,也不要污染用户环境。