如何同时进行多篇文章的翻译-GCTT 项目

栏目: 编程工具 · 发布时间: 5年前

内容简介:一个 PR 提交了多篇文章,这和流程中的『PR 请只包含一篇文章的翻译成果』的要求是冲突。对于熟悉 Git 开发流程人来说,是一个很简单的问题,利用 Git 的分支。下面我们会介绍这种方法:

GCTT 项目的工作流程为: 选题->翻译->提交->校验->发布。如果译者每次都按照此流程完成一篇译文,再翻译下一篇的时,只要在 master 这个分支上进行简单操作即可。有时候,可能同时进行几篇文章的翻译,如果都在 Master 分支上工作,就有可能出现这样的情况:

如何同时进行多篇文章的翻译-GCTT 项目

一个 PR 提交了多篇文章,这和流程中的『PR 请只包含一篇文章的翻译成果』的要求是冲突。对于熟悉 Git 开发流程人来说,是一个很简单的问题,利用 Git 的分支。下面我们会介绍这种方法:

Fork studygolang/GCTT 仓库

如何同时进行多篇文章的翻译-GCTT 项目

成功 Fork 后,你会在自己的账号下,发现 GCTT 的仓库。

如何同时进行多篇文章的翻译-GCTT 项目

下载自己的仓库的 master 分支到本地

anonymous2123 为我们的测试账号,你可以将 anonymous2123 替换成你自己的账号运行以下命令。

λ git clone https://github.com/anonymous2123/GCTT.git
Cloning into 'GCTT'...
remote: Counting objects: 7459, done.
remote: Compressing objects: 100% (11/11), done.
remote: Total 7459 (delta 5), reused 14 (delta 5), pack-reused 7443
Receiving objects: 100% (7459/7459), 12.65 MiB | 973.00 KiB/s, done.
Resolving deltas: 100% (4979/4979), done.

利用分支翻译

一个重要的原则是, 一个分支只对应一篇文 ,这里隐藏了一个问题,分支应该从哪里创建出来,我们的建议是保持 master 分支不动,所有的翻译分支都从 master 分支创建出来。 了解更多关于分支

创建 trans_article_1 分支,并切换到该分支

git branch trans_article_1
git checkout trans_article_1

或者使用 -b 参数一步达成

git checkout -b trans_article_1

接下来,就可以在该分支进行翻译。翻译完成后,将工作提交到分支之中。

在正式推送到 Github 之前,你需要保证和 studygolang/GCTT 是同步的,以防止在提出 PR 的时候出现冲突。

git remote add upstream https://github.com/studygolang/GCTT.git // 只需要第一次做,之后不需要该步骤
git fetch upstream
git rebase upstream/master

trans_article_1 分支推动到你的 Github 仓库中,并以此在 Github 中创建相应的分支。

git push -f origin trans_article_1

Github 的效果如下,有 mastertrans_article_1 两个分支:

如何同时进行多篇文章的翻译-GCTT 项目

最后,你只需要像在 master 分支一样,在 trans_article_1 分支向 studygolang/GCTT 提出 PR 请求。

如何同时进行多篇文章的翻译-GCTT 项目

利用分支进行多篇翻译

当你同时进行另一篇翻译的时候,你需要回到 master 分支下,再创建一个新分支 trans_article_2 。注意不要在 trans_article_1 中创建 trans_article_2 分支。如此做,就意味着你把你上一篇翻译的文章引入到这一篇的分支中,在提交 PR 时,就会出现两篇文章,这不满足『PR 请只包含一篇文章的翻译成果』的要求。

git checkout master 
git checkout -b trans_article_2

trans_article_2 分支中,执行相同的流程: 翻译,commit,与 studygolang/GCTT 同步,提交到 Github 中,提出 PR,最后完成翻译。

总结

以上的流程中,你有几篇文章,就有会几个分支,每一个分支都会向 studygolang/GCTT 提出自己 Pull Request。如果你需要修订你某一分支的提交,并不会影响其他分支。

这只是 Git&Github 的很小的一个应用场景,如果你想了解更多关于 Git 的知识,Git 的官方文档,或是 《Pro Git》 都不错的方式。


以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

数学世纪

数学世纪

皮耶尔乔治·奥迪弗雷迪 / 胡作玄、胡俊美、于金青 / 上海科学技术出版社 / 2012-1 / 28.00元

《数学世纪:过去100年间30个重大问题》以简短可读的方式论述了整个20世纪的数学。20世纪的数学博大精深,新兴领域及学科的建立发展,许多经典问题得到解决,大量新的有意义的问题的引入,为数学带来了活力。《数学世纪:过去100年间30个重大问题》介绍了数学基础,20世纪的纯粹数学、应用和计算数学,以及目前未解的重要问题,中间穿插了希尔伯特的23个问题的解决情况、菲尔兹奖和沃尔夫奖得主的工作成就等。一起来看看 《数学世纪》 这本书的介绍吧!

随机密码生成器
随机密码生成器

多种字符组合密码

URL 编码/解码
URL 编码/解码

URL 编码/解码

MD5 加密
MD5 加密

MD5 加密工具