forked from TortoiseGit/TortoiseGit
-
Notifications
You must be signed in to change notification settings - Fork 0
/
HowToContribute.txt
188 lines (141 loc) · 7.86 KB
/
HowToContribute.txt
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
Checklist (and a short version for the impatient):
Please also see https://tortoisegit.org/contribute/!
Submission:
- open an issue on https://tortoisegit.org/issues or go to an
issue you want to fix. Then you have the following options:
. attach a patch there
. provide a link to a branch you want the maintainers to pull from
. open a GitLab merge request and put the link into the issue
. open a GitHub pull request and put the link into the issue
For existing issues it is recommended to start commenting on the issue
in order to discuss possible solutions before starting coding.
Commits:
- make commits of (small) logical units
- do not check in commented out code, unrelated changes or unneeded files
- the subject (first line of the commit message) should be a short
description and should skip the full stop. If it is about a bug
report/issue, use "Fixed issue #NUMBER: ISSUE'S TITLE"
- the second line of commit message should be an empty line
- the body which starts from the third line should provide a meaningful
commit message
- add a "Signed-off-by: Your Name <[email protected]>" line to the commit
message to confirm that you agree to the Developer's Certificate of
Origin.
please use your real name.
Coding style:
- based on Visual Studio default coding style (try to copy & paste)
- the old code migrates to new coding style only when modifying it.
- variable definitions (as it is a type definition; e.g., CGitHash* name
and CGitHash& name)
- for `if`, `for`, `while` a spaces between the keyword and the
parenthesis (e.g., if ()).
- braces go on the next line for `if`, `for`, `else`, ...
- If an `if` contains only one action, no braces needed.
- function calls, there is no space before the parenthesis (e.g, method()).
- no spaces before and after parentheses (e.g., (something)).
- spaces between &&, + and other operands also after comma(,).
- no variable shadowing.
- for variable names: we don't have a strict rule here, should be speak
for it self.
- try not to nest too deeply and return as early as possible.
- Only use `this` if needed.
Longer version:
(0) Make separate commits for logically separate changes.
Unless your patch is really trivial, you should not be sending
out a patch that was generated between your working tree and
your commit head. Instead, always make a commit with complete
commit message and generate a series of patches from your
repository.
Give an explanation for the change(s) that is detailed enough so
that people can judge if it is good thing to do, without reading
the actual patch text to determine how well the code does what
the explanation promises to do.
If your description starts to get too long, that's a sign that you
probably need to split up your commit to finer grained pieces.
That being said, patches which plainly describe the things that
help reviewers check the patch, and future maintainers understand
the code, are the most beautiful patches. Descriptions that summarise
the point in the subject well, and describe the motivation for the
change, the approach taken by the change, and if relevant how this
differs substantially from the prior version, are all good things
to have.
Oh, another thing. We are picky about whitespaces. To help ensure this
does not happen, run git diff --check on your changes before you commit.
(1a) Generate your patch using git tools out of your commits (Patch serial)
git based diff tools generate unidiff which is the preferred format.
Please make sure your patch does not include any extra files
which do not belong in a patch submission. Make sure to review
your patch after generating it, to ensure accuracy. Before
sending out, please make sure it cleanly applies to the "master"
branch head.
(1b) Create a merge/pull request
Push your changes to a public repository. Use a brief branch name
describing your changes.
Please make sure your pull request does not include any extra files
which do not belong in a submission. Make sure to review your patch
after generating it, to ensure accuracy.
There is no need to generate a "formal" pull request. The URL and
branchname is necessary - or create a GitLab merge request
(https://gitlab.com/tortoisegit/tortoisegit/) or a GitHub pull request
(https://github.com/TortoiseGit).
(2) Sign your work
To improve tracking of who did what, we've borrowed the
"sign-off" procedure from the Linux kernel project on patches
that are being emailed around. Although TortoiseGit is a lot
smaller project it is a good discipline to follow it.
The sign-off is a simple line at the end of the explanation for
the patch, which certifies that you wrote it or otherwise have
the right to pass it on as a open-source patch. The rules are
pretty simple: if you can certify the below:
Developer's Certificate of Origin 1.1
By making a contribution to this project, I certify that:
(a) The contribution was created in whole or in part by me and I
have the right to submit it under the open source license
indicated in the file; or
(b) The contribution is based upon previous work that, to the best
of my knowledge, is covered under an appropriate open source
license and I have the right under that license to submit that
work with modifications, whether created in whole or in part
by me, under the same open source license (unless I am
permitted to submit under a different license), as indicated
in the file; or
(c) The contribution was provided directly to me by some other
person who certified (a), (b) or (c) and I have not modified
it.
(d) I understand and agree that this project and the contribution
are public and that a record of the contribution (including all
personal information I submit with it, including my sign-off) is
maintained indefinitely and may be redistributed consistent with
this project or the open source license(s) involved.
then you just add a line saying
Signed-off-by: Random J Developer <[email protected]>
This line can be automatically added by Git and TortoiseGit.
Also notice that a real name is used in the Signed-off-by: line. Please
don't hide your real name.
If you like, you can put extra tags at the end:
1. "Reported-by:" is used to credit someone who found the bug that
the patch attempts to fix.
2. "Acked-by:" says that the person who is more familiar with the area
the patch attempts to modify liked the patch.
3. "Reviewed-by:", unlike the other tags, can only be offered by the
reviewer and means that she is completely satisfied that the patch
is ready for application. It is usually offered only after a
detailed review.
4. "Tested-by:" is used to indicate that the person applied the patch
and found it to have the desired effect.
You can also create your own tag or use one that's in common usage
such as "Thanks-to:", "Based-on-patch-by:", or "Mentored-by:".
------------------------------------------------
An ideal patch flow
Here is an ideal patch flow for this project the current maintainer
suggests to the contributors:
(0) You come up with an itch. You code it up.
For exisiting issues it is recommended to start commenting on the issue
in order to discuss possible solutions before starting coding.
(1) Open an issue on https://tortoisegit.org/issues or attach
your changes to another already reported issue. Attach the patches
or provide a merge/pull request (URL branch) there.
(2) You get comments and suggestions for improvements. You may
even get them in a "on top of your change" patch form.
(3) Polish, refine, and re-send. Go back to step (2).
(4) The patch will be applied to master.