4.2 KiB
Write A Recipe Even If You Don't Know C
介绍
chsrc
不仅是一个命令行工具,同时也是一个换源框架,它甚至使你能够在不了解C语言的情况下编写出新的换源方法(recipe)。
我鼓励你为新的软件添加换源支持,因为通过 chsrc
这将非常简单,你的贡献也将非常有价值。理论上每一个 recipe
都需要有专人长时间维护 (招募)。
-
本项目采用
GPLv3+
协议,是真正的自由软件,而非仅仅是开源软件 -
代码规范灵活遵循
GNU
标准(若标准干扰了可维护性,则并不采纳) -
高度模块化,目录结构清晰易懂
-
极小依赖,极易构建,只需要
GCC
或Clang
即可编译 -
易于将
shell
脚本转换为等价的recipe
-
已有大量
recipe
可提供参考,并提供了 recipe template 供直接使用 -
提供持续关注镜像站可用性的协作平台:
成功案例:
基本概念
-
target
: 所要换源的目标 -
category
: 是target category
的简写,即target
所属的类别,可以是 编程语言,操作系统,软件 三类之一- 在目录中,三者分别为
lang
,os
,ware
- 在代码中,三者前缀分别为
pl
,os
,wr
- 在目录中,三者分别为
-
mirror
: 是mirror site
的简写,指镜像站,如清华大学开源软件镜像站 -
source
: 该target
所能换的具体的源,由mirror
提供服务,往往一个mirror
会提供许多source
-
recipe
: 是为一个target
定义的具体换源方法,请参考src
目录中的recipe
目录 -
feature
: 一个target
可以支持的功能,比如能否重置回上游默认源等 -
镜像源: 为了方便,偶尔我们将直接称
mirror
和/或source
为镜像源,这只是一种方便性的称呼,可以统称二者,也可以根据上下文指代二者之一
编写 recipe
步骤
-
确定你要编写的
target
的标准名称,创建Target-Name.c
文件大小写需严格按官方,若名称包含空格,需使用
-
代替空格 -
根据类别将上述文件放在
recipe/
目录的某个子目录中 -
复制 recipe template 的内容到上述文件中,并替换
<...>
占位符 -
参考现有
recipe
的写法- 看一眼就能上手的参照物是 PHP recipe
- 最好的参照物是 Ruby recipe
- 组换源参照物是 Python Group recipe
-
在 Wiki 中记录的镜像站中寻找可用源;可以额外补充镜像站
并创建或更新对应
target
的镜像站可用状态 Wiki 页 -
可以使用这些函数:
framework/core.c
中以chsrc_
开头的所有函数或宏xy.h
中以xy_
开头的所有函数或宏
-
在
recipe/menu.c
中添加用户可以使用的target
别名 -
编译、运行、测试 (how?),若无问题可提交 Pull Request
开发准则
-
代码高度可移植
-
Convention over Configuration
-
NO UFO 原则: 不要乱丢文件到$HOME等目录,尤其是使用各种隐晦的文件名
chsrc
主程序不提供配置文件,不提供数据文件,干净无污染。那么在实现recipe
的时候,除了备份文件外,也不要污染用户环境。