使用 git 进行 Debian 网站开发

使用 Git 存储库开展工作

让我们直奔主题——本节中您将了解如何创建主存储库的本地副本、如何使本地副本保持最新,以及如何提交您的工作。我们也会介绍如何开展翻译工作。

获取一份本地副本

首先,安装 Git。然后,配置 Git 并输入您的姓名和电子邮件地址。如果您是 Git 的新用户,先阅读通用的 Git 文档可能是个好主意。

下一步是克隆存储库(换句话说,对其创建本地副本)。有两种方法:

提示:克隆整个 webwml 存储库需要下载大约 1.3 GB 的数据,如果您的网络连接太慢或不稳定,这个数据量就太大了。所以,可以先以最小深度进行克隆,以减少首次下载的数据量:

  git clone git@salsa.debian.org:webmaster-team/webwml.git --depth 1

获得可用的(浅)存储库后,您可以加深本地副本,并最终将其转换为完整的本地存储库:

  git fetch --deepen=1000 # 为仓库加深 1000 次提交
  git fetch --unshallow   # 获取所有未获取的提交,将仓库转换成完整的

您也可以仅检出部分页面,如下所示:

  1. git clone --no-checkout git@salsa.debian.org:webmaster-team/webwml.git
  2. cd webwml
  3. git config core.sparseCheckout true
  4. webwml 中创建文件 .git/info/sparse-checkout,定义您想要检出的内容。例如,如果您只想要基本文件、英语、加泰罗尼亚语和西班牙语翻译,文件内容应该像下面这样:
          /*
          !/[a-z]*/
          /english/
          /catalan/
          /spanish/
        
  5. 最后,您就可以检出库:git checkout --

提交本地修改

令您的本地仓库保持最新

每隔几天(也一定要在开始一些编辑工作之前!),您应该运行一次

  git pull

以从存储库中获取已被更改的文件。

强烈建议在执行 git pull 和开始编辑文件之前保持本地 Git 工作目录的干净。如果您有未提交的更改,或者当前分支的远程存储库中不存在的本地提交,则执行 git pull 将会自动创建合并提交,甚至会由于冲突而导致拉取失败。请考虑将未完成的工作保存在另一个分支中,或使用 git stash 之类的命令。

注意:Git 是一个分布式(而非集中式)版本控制系统。这意味着当您提交更改时,它们将仅存储在本地存储库中。要与他人共享它们,您还需要将所做的更改推送到 Salsa 上的中央存储库。

示例:编辑文件

让我们看一个更实际的例子,也就是典型的编辑过程。我们假设您已经使用 git clone 获得了库的一份本地副本。接下来的步骤是:

  1. git pull
  2. 现在您可以开始编辑并对文件进行修改。
  3. 当您完成后,使用以下命令将您的更改提交到本地存储库:
        git add /path/to/file(s)
        git commit -m "Your commit message"
        
  4. 如果您有对远程 webwml 存储库的不受限制的写入权限,那么现在可以将您所做的更改直接推送到 Salsa 存储库中:git push
  5. 如果您无权直接写入 webwml 存储库,请考虑使用合并请求提交您的更改,或寻求其他开发人员的帮助。

在 Git 提交中关闭 Debian 的缺陷

如果您的提交日志条目中包含 Closes: #nnnnnn,那么在您推送您的更改后,缺陷编号 #nnnnnn 将会被自动关闭。精确的格式与 Debian 政策中的介绍相同。

使用 HTTP/HTTPS 链接

许多 Debian 网站都支持 SSL/TLS,因此请尽可能使用 HTTPS 链接。但是,某些 Debian/DebConf/SPI 等网站要么不具有 HTTPS 支持,要么仅使用 SPI 数字证书认证机构(并不是一个被所有浏览器信任的 SSL 证书认证机构)。为了避免给非 Debian 用户带来错误消息的困扰,请不要使用 HTTPS 链接到此类站点。

Git 存储库会拒绝那些包含使用纯 HTTP 链接到支持 HTTPS 的 Debian 网站的内容或包含使用 HTTPS 链接到已知不支持 HTTPS 或仅使用 SPI 签名的证书的 Debian/DebConf/SPI 网站的内容的提交。

开展翻译工作

翻译应始终与相对应的英文文件同步并保持最新。翻译文件中的 translation-check 头用于跟踪当前翻译所基于的英语文件的版本。如果您更改了已翻译的文件,则需要更新 translation-check 头以匹配英语文件中相应更改的 Git 提交哈希值。您可以使用以下命令找到该哈希值:

  git log path/to/english/file

如果您要对一个文件新建翻译,请使用 copypage.pl 脚本,它将为您的语言创建一个模板,该模板包含了正确的翻译头。

使用 smart_change.pl 进行翻译修改

smart_change.pl 是一个脚本,目的是让同时更新原始文件及其翻译更为容易。有两种方法供您使用,选择哪种取决于您进行的更改。

以下步骤说明了如何使用 smart_change.pl,以及当手动修改文件时,如何只更新 translation-check 头:

  1. 对原始文件进行更改,然后提交。
  2. 更新翻译。
  3. 运行 smart_change.pl -c COMMIT_HASH(使用对原始文件的更改产生的提交哈希值)。它会获取该更改,并更新已翻译文件的头。
  4. 检查更改(例如,使用 git diff)。
  5. 提交翻译更改。

或者,您可以使用正则表达式来一次性对文件进行多个更改:

  1. 运行 smart_change.pl -s s/FOO/BAR/ origfile1 origfile2 ...
  2. 检查更改(例如,使用 git diff)。
  3. 提交原始文件。
  4. 运行 smart_change.pl origfile1 origfile2(即,这次不带正则表达式)。它就会只更新已翻译文件的头。
  5. 最后,提交翻译更改。

必须承认,这比第一个例子更麻烦一点,因为涉及到两次提交,但是,由于 Git 哈希值的工作方式,这是无法避免的。

Git 存储库写入权限

整个 Debian 网站源代码都使用 Git 管理。它位于 https://salsa.debian.org/webmaster-team/webwml。默认情况下,不允许访客推送自己的提交到源代码存储库中。如果您想要对 Debian 网站作出贡献,您需要一些许可才能获得对存储库的写入权限。

不受限制的写入权限

如果您需要对存储库的不受限制的写入权限(例如,您打算成为频繁提交的贡献者),请在登录到 Debian Salsa 平台后通过 https://salsa.debian.org/webmaster-team/webwml 网页界面请求写入权限。

如果您刚开始参与 Debian 网站开发,并且没有经验,请在请求不受限制的写入权限之前发送电子邮件到 debian-www@lists.debian.org 介绍一下您自己。请您考虑在自我介绍中提供更多有用的信息,例如您打算对网站的哪个部分进行修改、您说哪种语言,以及是否有 Debian 团队的其他成员可以为您担保。

合并请求(Merge Request)

获得对存储库的不受限制的写入权限并不是必需的——您可以随时提交合并请求,并让其他开发人员检查并接受您的成果。请使用由 Salsa GitLab 平台通过其网页界面提供的标准程序提交合并请求,并请阅读以下两篇文档:

注意,并不是所有的网站开发人员都随时查看合并请求,所以您可能需要等一段时间才能收到反馈。如果您不确定所作的贡献是否会被接受,请发送电子邮件至 debian-www 邮件列表请求核查。

接收通知

如果您正在 Debian 网站上开展工作,您可能想要知道 webwml 存储库的动向。有两种方法可以让您始终处于圈子内:提交通知和合并请求通知。

接收提交通知

我们已经在 Salsa 中配置好了 webwml 项目,提交会显示在 IRC 频道 #debian-www 中。

如果您想要在 webwml 存储库中有提交时通过电子邮件接收通知,请按照以下步骤通过 tracker.debian.org 订阅 www.debian.org 伪软件包并在其中激活 vcs 关键字(仅需一次):

  1. 打开网页浏览器并访问 https://tracker.debian.org/pkg/www.debian.org
  2. 订阅 www.debian.org 伪软件包(如果您尚未在其它情况下使用过 tracker.debian.org,则可以使用 SSO 通过验证或使用电子邮件和密码进行注册)。
  3. 跳转到 https://tracker.debian.org/accounts/subscriptions,然后点击 modify keywords,选中 vcs(如果其未被选中)并保存。
  4. 从现在开始,每当有人提交更改到 webwml 存储库时,您将收到电子邮件。

接收合并请求通知

如果您想要在 Salsa 上的 webwml 存储库收到新的合并请求(Merge Request)的时候得到电子邮件提醒,您可以在网页界面上配置您的通知设置。步骤如下:

  1. 登陆您的 Salsa 帐号并前往项目页面。
  2. 点击项目主页顶部的铃铛图标。
  3. 选择您所需的通知级别。