博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
参与 Qt 文档翻译项目
阅读量:6454 次
发布时间:2019-06-23

本文共 1990 字,大约阅读时间需要 6 分钟。

Qt 是一个开源的 C++ 库,源代码十分庞大。如果你想为 Qt 作出自己的贡献,却又苦于找不到入手点,那么,就从文档翻译开始吧!

以前我曾经在 sourceforge.net 上面开启过一个翻译项目,而今天,我们试图完成一个真正的文档工程:其结果是提交到 Qt 的代码库,让全世界所有人都阅读到你翻译的代码。

Qt 的源代码使用 git 作为版本控制系统。git 是一个分布式版本控制系统,类似于 SVN(而后者是中央集权式的版本控制系统)。简单来说,就是可以把你的文件的每个版本详尽的记录下来,并且可以恢复到任意版本;同时,如果多人同时修改同一文件,git 可以保证你的修改不会丢失。由于 Qt 的代码库已经建立完全,所以,我们的工作流程是,从 Qt 的 git 版本库 pull 下来所有的源文件(这一过程在 SVN 中称为 check out,也就是签出),然后做自己的修改,修改完毕后 commit 到自己的 git 库(这是与 SVN 不同的地方,SVN 的 commit 会将你的修改提交到 SVN 代码库,而 git 的 commit 只是将修改提交到本地资源库。也就是说,每个客户端都有一个完整的 git 资源库,这也就是“分布式”的含义),最后将本地库修改的部分一次性全部 push 到远程资源库(这一步才相当于 SVN 的 commit 操作)。这就是 git 的简单使用步骤,了解了这些之后,我们才能将自己的翻译提交到 Qt 代码库。

git 在 Linux 下应用广泛,Linux kernel 即使用 git 做版本控制的。Windows 下,你可以通过安装 MSYSGIT 从而使用 git。如果你希望为 Qt 做出自己的贡献,建议先仔细学习下 git 的使用。

我们的项目地址是在 。打开这个网页,可以看到页面上方有我们项目的地址:

这里有三个选项。如果你的账号没有加入 commiter,那么就只有两个: GIT 和 HTTP。首先,我们根据它给出的地址,使用下面的命令将所有源文件下载到本地:

        git clone git://gitorious.org/~cavendish/qt/qt-l10n-zh_cn.git

注意,这一过程会很慢,鉴于国内网络的速度,大概要有半个小时或者更长的时间,总计大约 800M 以上。这时,你就有了所有的源文件。下面来到 doc/src,这里面放置的就是 Qt 文档的源代码。我们所要做的,就是将这里面的所有文件翻译成中文。在 src 下面已经建立了 zh_CN 文件夹,这里面就是我们的工作目录。当你翻译某一文档的时候,先将它复制到 zh_CN 文件夹下,然后对其进行翻译。注意,不要修改文件中的标签,例如 \list 或者 {} 内的数据,这些都是在生成文档的时候所必需的。我们要做的是将其中的显示内容(如果你不确定哪些是显示出来,或者显示到什么地方的,不妨打开生成的文件对照着翻译)翻译成中文。当你完成之后,使用

        git commit

将所作修改提交到本地资源库。最后,使用 git push 即可提交到远程资源库。这样,我们的 qt-l10n-zh_CN 资源库就有了你所做的工作。然后,你要做的是,点击页面右侧的 Request merge 连接,向 Qt 资源库提交一个合并请求。这一操作只需要做一次,目的是要你同一一个法律条款。当你提交了合并请求并获得许可之后,你的代码就已经加入到 Qt 代码库之中了。别人在 pull 最新代码的时候,就可以获得你所提交的代码。最后说明一点,为了便于管理,我们希望你只提交唯一一次 merge request,目的就是同意那个法律条款,之后,你所要做的就是将自己的修改 push 到 qt-l10n-zh_CN 资源库,由资源库的 creator 在 Qt 发布之前向 Qt 做 merge request。这样就不需要每个人都做这一请求了。

这就是我们大体的流程。如果你还不是 commiter,你是没有权限进行 push 操作的。此时,你可以使用页面右侧的 Clone repository 连接创建自己的资源库,翻译结束后做 qt-l10n-zh_CN 的 merge request,这样,我们就可以将你的修改 merge 到 qt-l10n-zh_CN,然后再进行统一的提交。

我们希望能够通过这一项目,将中文版的 Qt 文档提交到 Qt 源代码库中,让更多人了解、学习 Qt。如果你不熟悉版本控制系统,或许会感到十分不便,不过,如果你试着去学习,就会发现版本控制系统的好处,也会越来越多地在自己的项目中应用起来。

本文转自 FinderCheng 51CTO博客,原文链接: 

http://blog.51cto.com/devbean/389439

转载地址:http://ibbzo.baihongyu.com/

你可能感兴趣的文章
URL重定向/跳转漏洞
查看>>
Android进程启动与Activity显示
查看>>
浏览器从输入URL到页面加载过程(+1白话精简讲解)
查看>>
一文读懂物体分类AI算法:LeNet-5 AlexNet VGG Inception ResNet MobileNet
查看>>
JavaScript 事件节流和事件防抖
查看>>
iOS 中 weak 的实现原理
查看>>
android MVC && MVP && MVVM分析和对比
查看>>
iOS 串行语音播报解决方案(实现支付宝语音收款功能)
查看>>
Nginx 学习系列(三) ------------- alias、root指令区别
查看>>
React 生命周期
查看>>
干货:分布式系统学习笔记
查看>>
“我想要”的疑惑
查看>>
android位运算讲解与实战
查看>>
180道Java技术面试题:阿里11面试+网易+百度+美团!
查看>>
Android简易柱状图和曲线图表实现
查看>>
一款基于Handler的Android定时器与倒计时器
查看>>
第八章:使用拦截器记录你的SpringBoot的请求日志
查看>>
演讲实录|马晓宇:When TiDB Meets Spark
查看>>
日推笔记
查看>>
JNI引用
查看>>