Commit 12941b07 authored by Rusty Russell's avatar Rusty Russell

ccanlint: neaten info_summary_single_line with new doc_section info.

parent b2826f4c
...@@ -4,50 +4,34 @@ ...@@ -4,50 +4,34 @@
#include <ccan/talloc/talloc.h> #include <ccan/talloc/talloc.h>
#include <ccan/str/str.h> #include <ccan/str/str.h>
/* Summary line is form '<identifier> - ' (spaces for 'struct foo -') */
/* slightly modified from doc_extract-core.c */
static unsigned int is_summary_line(const char *line)
{
unsigned int id_len;
id_len = strspn(line, IDENT_CHARS" *");
if (id_len == 0)
return 0;
if (strspn(line, " ") == id_len)
return 0;
if (!strstarts(line + id_len-1, " - "))
return 0;
return id_len - 1;
}
static void check_info_summary_single_line(struct manifest *m, static void check_info_summary_single_line(struct manifest *m,
bool keep, bool keep,
unsigned int *timeleft, unsigned int *timeleft,
struct score *score) struct score *score)
{ {
int i = 0; struct list_head *infodocs = get_ccan_file_docs(m->info_file);
get_ccan_line_info(m->info_file); struct doc_section *d;
score->total = 1;
for (i = 0; i < m->info_file->num_lines; ++i) {
if (is_summary_line(m->info_file->lines[i])) {
if (strspn(m->info_file->lines[i+1], " *") == strlen(m->info_file->lines[i+1])) {
/* valid summary line */
score->error = NULL;
score->pass = true; score->pass = true;
score->score = 1; list_for_each(infodocs, d, list) {
} else { const char *after;
/* invalid summary line - line following summary line should be empty */
if (!streq(d->type, "summary"))
continue;
/* line following summary line should be empty */
after = m->info_file->lines[d->srcline+1];
if (after && strspn(after, " *") != strlen(after)) {
score->pass = false; score->pass = false;
score->score = 0; score->score = 0;
score->error = "invalid summary line - not on a single line:"; score_file_error(score, m->info_file, d->srcline+1,
score_file_error(score, m->info_file, i+1, "summary is not on a single line"); m->info_file->lines[d->srcline]);
} score_file_error(score, m->info_file, d->srcline+2,
break; m->info_file->lines[d->srcline+1]);
} }
} }
} }
struct ccanlint info_summary_single_line = { struct ccanlint info_summary_single_line = {
.key = "info_summary_single_line", .key = "info_summary_single_line",
.name = "Module has a single line summary in _info", .name = "Module has a single line summary in _info",
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment