X-Git-Url: http://git.ozlabs.org/?a=blobdiff_plain;ds=sidebyside;f=tools%2Fccanlint%2Ftests%2Ftrailing_whitespace.c;h=2a301ea8b1c077af8bb369e1d2c64cf893080a8d;hb=f9423c171395571f9880286190d9cf63da147668;hp=6b831a727550c400476727e17515403f91ecada3;hpb=357700fd05c2cf25563a0058fd68f2ffea827e74;p=ccan-lca-2011.git diff --git a/tools/ccanlint/tests/trailing_whitespace.c b/tools/ccanlint/tests/trailing_whitespace.c index 6b831a7..2a301ea 100644 --- a/tools/ccanlint/tests/trailing_whitespace.c +++ b/tools/ccanlint/tests/trailing_whitespace.c @@ -1,9 +1,11 @@ /* Trailing whitespace test. Almost embarrassing, but trivial. */ #include #include +#include #include -static char *report_on_trailing_whitespace(const char *line) +/* FIXME: only print full analysis if verbose >= 2. */ +static char *get_trailing_whitespace(const char *line) { const char *e = strchr(line, 0); while (e>line && (e[-1]==' ' || e[-1]=='\t')) @@ -19,32 +21,38 @@ static char *report_on_trailing_whitespace(const char *line) return talloc_asprintf(line, "'%s'", line); } -static void *check_trailing_whitespace(struct manifest *m) +static void check_trailing_whitespace(struct manifest *m, + bool keep, + unsigned int *timeleft, + struct score *score) { - char *report; - - report = report_on_lines(&m->c_files, report_on_trailing_whitespace, - NULL); - report = report_on_lines(&m->h_files, report_on_trailing_whitespace, - report); - - return report; -} - -static const char *describe_trailing_whitespace(struct manifest *m, - void *check_result) -{ - return talloc_asprintf(check_result, - "Some source files have trailing whitespace:\n" - "%s", (char *)check_result); + struct list_head *list; + struct ccan_file *f; + unsigned int i; + + foreach_ptr(list, &m->c_files, &m->h_files) { + list_for_each(list, f, list) { + char **lines = get_ccan_file_lines(f); + for (i = 0; i < f->num_lines; i++) { + char *err = get_trailing_whitespace(lines[i]); + if (err) { + score->error = "Trailing whitespace" + " found"; + score_file_error(score, f, i+1, err); + } + } + } + } + if (!score->error) { + score->pass = true; + score->score = score->total; + } } struct ccanlint trailing_whitespace = { - .key = "trailing-whitespace", + .key = "no_trailing_whitespace", .name = "Module's source code has no trailing whitespace", - .total_score = 1, .check = check_trailing_whitespace, - .describe = describe_trailing_whitespace, };