-
Notifications
You must be signed in to change notification settings - Fork 43
/
HACKING
212 lines (139 loc) · 5.78 KB
/
HACKING
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
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
Contributing to pyparted
This guide helps explain how to get your contributions accepted in to the
project. Coding style, patch generation, and how to submit patches are
all discussed here.
CODING STYLE FOR C
Please follow the coding style you see in the C source files here. The project
is developed on Linux, which gcc is the compiler. That affords us a lot of
flexibility with regards to standards, but try to adhere to ISO C99 whenever
possible and avoid using gcc extensions. There is a possibility that this
project may need to be ported to a non-gcc compiler.
Here are the major coding style highlights for this project:
1) Indentation is four spaces. Please do not use tab and do not use more
or less than 4 spaces. A lot of the source files have vim control
settings at the bottom so if you are using vim, the indentation will
automatically be set up properly with the Tab key. However, if you are
unlucky and do not have vim, just make sure you use 4 spaces for indent.
Editor hints will be accepted for other editors, so long as the additions
to the source files are minimal (i.e., we're not looking for editor
configuration files).
Examples:
GOOD:
int main(int argc, char **argv) {
int i;
i = EXIT_SUCCESS;
if (i == -1) {
return EXIT_FAILURE;
}
return i;
}
2) Spaces after keywords. Do not place an open paren next to 'if' or 'for'.
Examples:
GOOD:
if (i < j) {
for (i=0; i < 30; i++) {
BAD:
if(i < j) {
for(i=0; i < 30; i++) {
3) Open brace stays on the same line for the function declaration or
statement it belongs to. Examples:
GOOD:
if (i < j ) {
BAD:
if (i < j)
{
4) No brace-less blocks. If an 'if' test just requires one statement in
the block, do still wrap it in braces. This is to maintain consistency
with all blocks in the code. Examples:
GOOD:
if (i < j) {
printf("i is less than j!\n");
}
BAD:
if (i < j)
printf("i is less than j!\n");
5) No K&R style function declarations. Examples:
GOOD:
int main(int argc, char **argv) {
BAD:
int main(argc, argv)
int argc;
char **argv;
{
6) Let expressions breathe. There's no reason to remove all spaces from
a complex expression. Examples:
GOOD:
i = (a + b) << c >> d | e * f;
BAD:
i = (a+b)<<c>>d|e*f;
7) Function declarations have the return type on the same line as the
function. For long argument lists, wrap them to line up with the
parens. There is no space between the function name and the open
paren. Examples:
GOOD:
int main(int argc, char **argv) {
void check_a_variable(int a, char b, int c, struct astruct,
int *d, char *e, void *buf) {
BAD:
int
main (int argc, char **argv)
{
8) Name variables and functions using lowercase names and underscores rather
than CamelCase. Examples:
GOOD:
int c;
char *host_name = NULL;
void function_name(int argument);
BAD:
int counterForCountingThings;
char *hostName = NULL;
void functionName(int argument);
CODING STYLE FOR PYTHON
First, read PEP-8: http://www.python.org/dev/peps/pep-0008/
Second, please follow the coding style you see in the Python source files here.
Here are the major coding style highlights for this project:
1) 4-space indentation. Do not use tabs in Python code.
2) Use CamelCase for class names.
3) For method names, the standard CamelCase naming with the first
character being lowercase is preferred.
4) Use properties instead of get/set methods.
5) Use _ to prefix class variables accessed via properties.
6) Hide anything with __ prefixes if it does not need to be fully public.
7) List one module per import statement. Do not use a comma to list several
modules on one import line.
GENERATING PATCHES
When you make changes to the code, you should generate a patch to send
upstream. Before editing, it's a good idea to copy the original source
file to a new name so you can edit the other copy. Here is a basic
workflow:
$ cd pyparted-VERSION/src
$ cp -p _pedmodule.c _pedmodule.c.orig
$ vim _pedmodule.c # make your changes
Generating a patch is done using GNU diffutils or a diff(1) command
capable of producing a unified diff:
$ diff -u _pedmodule.c.orig _pedmodule.c > mypatch
Submit the 'mypatch' file and explain your changes and why we should merge
your changes.
If you are making a lot of changes to many files, it's probably easier to
use the git version control system. You can clone the upstream repository
and commit your changes locally and then generate a set of diffs against
the latest upstream code.
$ git clone https://github.com/dcantrell/pyparted.git
$ cd pyparted
$ # make your changes to files here
$ git add FILE # repeat this add/commit process for
$ git commit # each logical change to the code
$ git fetch
$ git rebase origin
$ git format-patch origin
The output of git format-patch will be a set of files containing a patch
for each add/commit you made locally. The patches will be made against
the latest upstream. Submit your patch files upstream.
SUBMITTING PATCHES
The best way to submit patches is to fork the repo on github and send a pull
request with your changes:
https://github.com/dcantrell/pyparted
Attach your patch and explanation and it'll be reviewed. There may be some
back and forth as your patch is reviewed and considered for inclusion.
Alternatively, you can email the project maintainer(s) directly. The git log
and AUTHORS file contain email addresses of those who work on pyparted.