diff options
Diffstat (limited to 'HACKING')
-rw-r--r-- | HACKING | 107 |
1 files changed, 74 insertions, 33 deletions
@@ -1,52 +1,69 @@ Contributing to pacman ====================== -Please read 'submitting-patches' and 'translation-help' in the same directory -as this file. +In addition to this file, please read `submitting-patches` and +`translation-help` in the same directory for additional info on contributing. Coding style ------------ 1. All code should be indented with tabs. (Ignore the use of only spaces in this file) By default, source files contain the following VIM modeline: - /* vim: set ts=2 sw=2 noet: */ ++ +[C] +code~~~~~~~~~~ +/* vim: set ts=2 sw=2 noet: */ +code~~~~~~~~~~ 2. When opening new blocks such as 'while', 'if', or 'for', leave the opening brace on the same line as the beginning of the codeblock. The closing brace gets its own line (the only exception being 'else'). Do not use extra - spaces around the parentheses of the block. ALWAYS use opening/closing - braces, even if it's just a one-line block. - - for(lp = list; lp; lp = lp->next) { - newlist = _alpm_list_add(newlist, strdup(lp->data)); - } - - while(it) { - ptr = it->next; - if(fn) { - fn(it->data); - } else { - return(1); - } - free(it); - it = ptr; - } + spaces around the parentheses of the block. ALWAYS use opening and closing + braces, even if it's just a one-line block. This reduces future error when + blocks are expanded beyond one line. ++ +[C] +code~~~~~~~~~~ +for(lp = list; lp; lp = lp->next) { + newlist = _alpm_list_add(newlist, strdup(lp->data)); +} + +while(it) { + ptr = it->next; + if(fn) { + fn(it->data); + } else { + return(1); + } + free(it); + it = ptr; +} +code~~~~~~~~~~ 3. When declaring a new function, put the opening and closing braces on their own line. Also, when declaring a pointer, do not put a space between the asterisk and the variable name. - - pmlist_t *_alpm_list_add(pmlist_t *list, void *data) - { - pmlist_t *ptr, *lp; - - ptr = list; - if(ptr == NULL) { - ... - } - -4. Comments should be ANSI-C89 compliant. That means no "// Comment" style; - use only "/* Comment */" style. ++ +[C] +code~~~~~~~~~~ +alpm_list_t *alpm_list_add(alpm_list_t *list, void *data) +{ + alpm_list_t *ptr, *lp; + + ptr = list; + if(ptr == NULL) { + ... + } + ... +} +code~~~~~~~~~~ + +4. Comments should be ANSI-C89 compliant. That means no `// Comment` style; + use only `/* Comment */` style. + + /* This is a comment */ + NOT + // This is a comment 5. Return statements should be written like a function call. @@ -62,34 +79,58 @@ Coding style NOT sizeof(*mylist); +7. When using strcmp() (or any function that returns 0 on success) in a + conditional statement, use != 0 or == 0 and not the negation (!) operator. + It reads much cleaner for humans (using a negative to check for success is + confusing) and the compiler will treat it correctly anyway. + + if(strcmp(a, b) == 0) + NOT + if(!strcmp(a, b)) + + Other Concerns -------------- +Header Includes +~~~~~~~~~~~~~~~ + Currently our #include usage is in messy shape, but this is no reason to continue down this messy path. When adding an include to a file, follow this general pattern, including blank lines: +[C] +code~~~~~~~~~~ #include "config.h" #include <standardheader.h> #include <another.h> #include <...> +code~~~~~~~~~~ Follow this with some more headers, depending on whether the file is in libalpm or pacman proper. For libalpm: +[C] +code~~~~~~~~~~ /* libalpm */ #include "yourfile.h" #include "alpm_list.h" #include "anythingelse.h" +code~~~~~~~~~~ For pacman: +[C] +code~~~~~~~~~~ #include <alpm.h> #include <alpm_list.h> /* pacman */ #include "yourfile.h" #include "anythingelse.h" +code~~~~~~~~~~ -vim: set ts=2 sw=2 et: +///// +vim: set ts=2 sw=2 syntax=asciidoc et: +///// |