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
@@ -21,17 +21,18 @@ typedef void (*cache_fill_fn)(void *cbdata); | |||
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 */ |
@@ -284,24 +284,25 @@ extern void *cgit_free_commitinfo(struct commitinfo *info); | |||
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); |
@@ -1,20 +1,23 @@ | |||
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); |