我想修复一个错误。我应该从哪里开始?

我想修复一个错误。我应该从哪里开始?

虽然我不是专业程序员,但我写过一两个程序。然而,如今每个工程师和科学家都会学习一点编程,因此我习惯用 Python、C 和 MATLAB 编写程序。现在我想回馈 Ubuntu 及其伟大的人们,并修复一个错误!

我查看了 bitesize 活动的列表,发现大多数问题对我来说都不是那么容易解决的,因为我怀疑这些问题需要花费大量时间才能解决,而我没有时间。但我发现这个对我来说它看起来很易于管理并且是一个很酷的功能。

由于我之前从未编写过补丁或发布过程序,所以我不知道从哪里开始。我应该从哪里开始解决这个问题?

底线:我应该从哪里开始、怎样开始修复这个家伙?

答案1

回答这个问题可能会很长而且很复杂,所以我将向您指出可用的资源,而不是在这里重新讨论它们。

文档

  1. 为 Ubuntu 开发做好准备
  2. 如何修复错误

教程

我们在整个周期内举办活动来帮助像你一样的人,具体来说,我们举办Ubuntu 开发者周在 IRC 中,这是一个现场教程和问答研讨会。如果您想参加,二月底将有一个!

以下是过去会话中的两个日志,可供您参考:

寻找机会的地方

  • 收成- 此工具会检查 Launchpad 中的所有补丁和软件包(甚至还会检查其他发行版)以查找补丁。其中许多补丁可以在 Ubuntu 中查找、应用、测试,然后修复,然后发送到上游。
  • 横扫- Launchpad 中某人附加到错误报告中的补丁列表。这些补丁可能有用,也可能没用,但仍然值得关注。

获取帮助

通过邮件列表或 IRC 联系 MOTU 是解决您遇到的个人问题的好方法:

反馈

我们花了大量时间来重新修改这个文档,使它尽可能简单易懂,如果你能记录下你的经验以及我们如何改进这个内容,那么知道如何让像你这样的人少受一点困扰将会非常有用。

答案2

Jorge 的概括性回答对于进入 Ubuntu 开发来说是一个很好的介绍,但让我们尝试更仔细地看一下您的具体问题......

Apport 的主要上游开发者和 Ubuntu 维护者是同一个人。这可以为您简化一些事情。您无需了解打包和补丁系统,最简单的方法是直接在上游代码上工作。

Apport 的开发托管于发射台。它使用 Bazaar 分布式版本控制系统来管理其源代码。修复的第一步你的错误是获取源代码。如果你以前没有使用过 Bazaar,五分钟 Bazaar 教程是一个很好的起点。

使用以下命令安装 Bazaar:

sudo apt-get install bzr

拉取apport的源代码:

bzr branch lp:apport

现在您可以开始 hacking 了。与大多数 VCS 一样,使用 Bazaar 时,每次提交只做一次更改是个好主意。您还应该使提交消息具有信息性。这样可以更轻松地查看您的更改。当您准备好进行第一次提交时,请运行:

bzr commit -m "My commit message. Did foo to bar in order to achieve baz."

继续进行更改和提交,直到您对错误已修复感到满意为止。对于最后一次提交,您还可以通过附加到--fixes lp:<bug_number>提交命令将其标记为修复错误。现在,您可以提交更改以供审核和纳入。

首先,您需要将其推送到 Launchpad 以使其公开可用:

bzr push lp:~<launchpad_username>/apport/<branch_name>

您的分支现在可以在以下位置找到:

https://code.launchpad.net/~<launchpad_username>/apport/<branch_name>/

bzr lp-open在分支中运行将在浏览器中打开该位置。

现在我们要提议合并。在该页面上,选择“提议合并”。

提议合并

在下一页中,选择您的目标分支并概述您的更改。

描述合并

您现在将有一个有效的合并提案。

积极审查

维护人员将审查您的更改。如果这些更改合适,它们将被合并并在下一个版本中可用。或者,提案可能会设置为“需要改进”,维护人员将与您讨论合并前应进行的其他更改。如果发生这种情况,请不要将其视为对您工作的个人拒绝。首次为新项目做出贡献时,通常有一些您可能没有意识到的小事,例如编码风格。

相关内容