author | Mark Lodato <lodatom@gmail.com> | 2010-09-04 15:09:57 (UTC) |
---|---|---|
committer | Mark Lodato <lodatom@gmail.com> | 2010-09-04 15:11:40 (UTC) |
commit | a4c58d92bfee0cf2e35ab1c5e828a6d790108a69 (patch) (unidiff) | |
tree | 4b6073081a04216525facaf06db956b4a08dffac | |
parent | bf8293d3196d49d6c4a48b254a04415183ca2762 (diff) | |
download | cgit-a4c58d92bfee0cf2e35ab1c5e828a6d790108a69.zip cgit-a4c58d92bfee0cf2e35ab1c5e828a6d790108a69.tar.gz cgit-a4c58d92bfee0cf2e35ab1c5e828a6d790108a69.tar.bz2 |
use __attribute__ to catch printf format mistakes
Use "__attribute__((format (printf,N,M)))", as is done in git, do catch
mistakes in printf-style format strings.
Signed-off-by: Mark Lodato <lodatom@gmail.com>
-rw-r--r-- | cache.h | 1 | ||||
-rw-r--r-- | cgit.h | 1 | ||||
-rw-r--r-- | html.h | 3 |
3 files changed, 5 insertions, 0 deletions
@@ -1,37 +1,38 @@ | |||
1 | /* | 1 | /* |
2 | * Since git has it's own cache.h which we include, | 2 | * Since git has it's own cache.h which we include, |
3 | * lets test on CGIT_CACHE_H to avoid confusion | 3 | * lets test on CGIT_CACHE_H to avoid confusion |
4 | */ | 4 | */ |
5 | 5 | ||
6 | #ifndef CGIT_CACHE_H | 6 | #ifndef CGIT_CACHE_H |
7 | #define CGIT_CACHE_H | 7 | #define CGIT_CACHE_H |
8 | 8 | ||
9 | typedef void (*cache_fill_fn)(void *cbdata); | 9 | typedef void (*cache_fill_fn)(void *cbdata); |
10 | 10 | ||
11 | 11 | ||
12 | /* Print cached content to stdout, generate the content if necessary. | 12 | /* Print cached content to stdout, generate the content if necessary. |
13 | * | 13 | * |
14 | * Parameters | 14 | * Parameters |
15 | * size max number of cache files | 15 | * size max number of cache files |
16 | * path directory used to store cache files | 16 | * path directory used to store cache files |
17 | * key the key used to lookup cache files | 17 | * key the key used to lookup cache files |
18 | * ttl max cache time in seconds for this key | 18 | * ttl max cache time in seconds for this key |
19 | * fn content generator function for this key | 19 | * fn content generator function for this key |
20 | * cbdata user-supplied data to the content generator function | 20 | * cbdata user-supplied data to the content generator function |
21 | * | 21 | * |
22 | * Return value | 22 | * Return value |
23 | * 0 indicates success, everyting else is an error | 23 | * 0 indicates success, everyting else is an error |
24 | */ | 24 | */ |
25 | extern int cache_process(int size, const char *path, const char *key, int ttl, | 25 | extern int cache_process(int size, const char *path, const char *key, int ttl, |
26 | cache_fill_fn fn, void *cbdata); | 26 | cache_fill_fn fn, void *cbdata); |
27 | 27 | ||
28 | 28 | ||
29 | /* List info about all cache entries on stdout */ | 29 | /* List info about all cache entries on stdout */ |
30 | extern int cache_ls(const char *path); | 30 | extern int cache_ls(const char *path); |
31 | 31 | ||
32 | /* Print a message to stdout */ | 32 | /* Print a message to stdout */ |
33 | __attribute__((format (printf,1,2))) | ||
33 | extern void cache_log(const char *format, ...); | 34 | extern void cache_log(const char *format, ...); |
34 | 35 | ||
35 | extern unsigned long hash_str(const char *str); | 36 | extern unsigned long hash_str(const char *str); |
36 | 37 | ||
37 | #endif /* CGIT_CACHE_H */ | 38 | #endif /* CGIT_CACHE_H */ |
@@ -264,50 +264,51 @@ extern struct cgit_context ctx; | |||
264 | extern const struct cgit_snapshot_format cgit_snapshot_formats[]; | 264 | extern const struct cgit_snapshot_format cgit_snapshot_formats[]; |
265 | 265 | ||
266 | extern struct cgit_repo *cgit_add_repo(const char *url); | 266 | extern struct cgit_repo *cgit_add_repo(const char *url); |
267 | extern struct cgit_repo *cgit_get_repoinfo(const char *url); | 267 | extern struct cgit_repo *cgit_get_repoinfo(const char *url); |
268 | extern void cgit_repo_config_cb(const char *name, const char *value); | 268 | extern void cgit_repo_config_cb(const char *name, const char *value); |
269 | 269 | ||
270 | extern int chk_zero(int result, char *msg); | 270 | extern int chk_zero(int result, char *msg); |
271 | extern int chk_positive(int result, char *msg); | 271 | extern int chk_positive(int result, char *msg); |
272 | extern int chk_non_negative(int result, char *msg); | 272 | extern int chk_non_negative(int result, char *msg); |
273 | 273 | ||
274 | extern char *trim_end(const char *str, char c); | 274 | extern char *trim_end(const char *str, char c); |
275 | extern char *strlpart(char *txt, int maxlen); | 275 | extern char *strlpart(char *txt, int maxlen); |
276 | extern char *strrpart(char *txt, int maxlen); | 276 | extern char *strrpart(char *txt, int maxlen); |
277 | 277 | ||
278 | extern void cgit_add_ref(struct reflist *list, struct refinfo *ref); | 278 | extern void cgit_add_ref(struct reflist *list, struct refinfo *ref); |
279 | extern int cgit_refs_cb(const char *refname, const unsigned char *sha1, | 279 | extern int cgit_refs_cb(const char *refname, const unsigned char *sha1, |
280 | int flags, void *cb_data); | 280 | int flags, void *cb_data); |
281 | 281 | ||
282 | extern void *cgit_free_commitinfo(struct commitinfo *info); | 282 | extern void *cgit_free_commitinfo(struct commitinfo *info); |
283 | 283 | ||
284 | extern int cgit_diff_files(const unsigned char *old_sha1, | 284 | extern int cgit_diff_files(const unsigned char *old_sha1, |
285 | const unsigned char *new_sha1, | 285 | const unsigned char *new_sha1, |
286 | unsigned long *old_size, unsigned long *new_size, | 286 | unsigned long *old_size, unsigned long *new_size, |
287 | int *binary, int context, int ignorews, | 287 | int *binary, int context, int ignorews, |
288 | linediff_fn fn); | 288 | linediff_fn fn); |
289 | 289 | ||
290 | extern void cgit_diff_tree(const unsigned char *old_sha1, | 290 | extern void cgit_diff_tree(const unsigned char *old_sha1, |
291 | const unsigned char *new_sha1, | 291 | const unsigned char *new_sha1, |
292 | filepair_fn fn, const char *prefix, int ignorews); | 292 | filepair_fn fn, const char *prefix, int ignorews); |
293 | 293 | ||
294 | extern void cgit_diff_commit(struct commit *commit, filepair_fn fn); | 294 | extern void cgit_diff_commit(struct commit *commit, filepair_fn fn); |
295 | 295 | ||
296 | __attribute__((format (printf,1,2))) | ||
296 | extern char *fmt(const char *format,...); | 297 | extern char *fmt(const char *format,...); |
297 | 298 | ||
298 | extern struct commitinfo *cgit_parse_commit(struct commit *commit); | 299 | extern struct commitinfo *cgit_parse_commit(struct commit *commit); |
299 | extern struct taginfo *cgit_parse_tag(struct tag *tag); | 300 | extern struct taginfo *cgit_parse_tag(struct tag *tag); |
300 | extern void cgit_parse_url(const char *url); | 301 | extern void cgit_parse_url(const char *url); |
301 | 302 | ||
302 | extern const char *cgit_repobasename(const char *reponame); | 303 | extern const char *cgit_repobasename(const char *reponame); |
303 | 304 | ||
304 | extern int cgit_parse_snapshots_mask(const char *str); | 305 | extern int cgit_parse_snapshots_mask(const char *str); |
305 | 306 | ||
306 | extern int cgit_open_filter(struct cgit_filter *filter); | 307 | extern int cgit_open_filter(struct cgit_filter *filter); |
307 | extern int cgit_close_filter(struct cgit_filter *filter); | 308 | extern int cgit_close_filter(struct cgit_filter *filter); |
308 | 309 | ||
309 | extern int readfile(const char *path, char **buf, size_t *size); | 310 | extern int readfile(const char *path, char **buf, size_t *size); |
310 | 311 | ||
311 | extern char *expand_macros(const char *txt); | 312 | extern char *expand_macros(const char *txt); |
312 | 313 | ||
313 | #endif /* CGIT_H */ | 314 | #endif /* CGIT_H */ |
@@ -1,24 +1,27 @@ | |||
1 | #ifndef HTML_H | 1 | #ifndef HTML_H |
2 | #define HTML_H | 2 | #define HTML_H |
3 | 3 | ||
4 | extern int htmlfd; | 4 | extern int htmlfd; |
5 | 5 | ||
6 | extern void html_raw(const char *txt, size_t size); | 6 | extern void html_raw(const char *txt, size_t size); |
7 | extern void html(const char *txt); | 7 | extern void html(const char *txt); |
8 | |||
9 | __attribute__((format (printf,1,2))) | ||
8 | extern void htmlf(const char *format,...); | 10 | extern void htmlf(const char *format,...); |
11 | |||
9 | extern void html_status(int code, const char *msg, int more_headers); | 12 | extern void html_status(int code, const char *msg, int more_headers); |
10 | extern void html_txt(const char *txt); | 13 | extern void html_txt(const char *txt); |
11 | extern void html_ntxt(int len, const char *txt); | 14 | extern void html_ntxt(int len, const char *txt); |
12 | extern void html_attr(const char *txt); | 15 | extern void html_attr(const char *txt); |
13 | extern void html_url_path(const char *txt); | 16 | extern void html_url_path(const char *txt); |
14 | extern void html_url_arg(const char *txt); | 17 | extern void html_url_arg(const char *txt); |
15 | extern void html_hidden(const char *name, const char *value); | 18 | extern void html_hidden(const char *name, const char *value); |
16 | extern void html_option(const char *value, const char *text, const char *selected_value); | 19 | extern void html_option(const char *value, const char *text, const char *selected_value); |
17 | extern void html_link_open(const char *url, const char *title, const char *class); | 20 | extern void html_link_open(const char *url, const char *title, const char *class); |
18 | extern void html_link_close(void); | 21 | extern void html_link_close(void); |
19 | extern void html_fileperm(unsigned short mode); | 22 | extern void html_fileperm(unsigned short mode); |
20 | extern int html_include(const char *filename); | 23 | extern int html_include(const char *filename); |
21 | 24 | ||
22 | extern int http_parse_querystring(const char *txt, void (*fn)(const char *name, const char *value)); | 25 | extern int http_parse_querystring(const char *txt, void (*fn)(const char *name, const char *value)); |
23 | 26 | ||
24 | #endif /* HTML_H */ | 27 | #endif /* HTML_H */ |