X-Git-Url: https://git.ozlabs.org/?p=ccan;a=blobdiff_plain;f=tools%2Fccanlint%2Fcompulsory_tests%2Fhas_info.c;h=ce131f85686ec88111c1b0ea709a04c77fbbcc50;hp=ed2d4c813c0c1b7d4a29f9b7de6b79aec59bb043;hb=1591860d84a9676820e94d8bd75d08a2c24ffef4;hpb=570c9c555f076e74f46141bb42b5d1d7ac89f632 diff --git a/tools/ccanlint/compulsory_tests/has_info.c b/tools/ccanlint/compulsory_tests/has_info.c index ed2d4c81..ce131f85 100644 --- a/tools/ccanlint/compulsory_tests/has_info.c +++ b/tools/ccanlint/compulsory_tests/has_info.c @@ -10,20 +10,22 @@ #include #include #include +#include -static void *check_has_info(struct manifest *m) +static void check_has_info(struct manifest *m, + bool keep, + unsigned int *timeleft, + struct score *score) { - if (m->info_file) - return NULL; - return m; -} - -static const char *describe_has_info(struct manifest *m, void *check_result) -{ - return "You have no _info file.\n\n" + if (m->info_file) { + score->pass = true; + score->score = score->total; + } else { + score->error = "You have no _info file.\n\n" "The file _info contains the metadata for a ccan package: things\n" "like the dependencies, the documentation for the package as a whole\n" "and license information.\n"; + } } static const char template[] = @@ -52,27 +54,31 @@ static const char template[] = " return 1;\n" "}\n"; -static void create_info_template(struct manifest *m, void *check_result) +static void create_info_template(struct manifest *m, struct score *score) { FILE *info; + const char *filename; if (!ask("Should I create a template _info file for you?")) return; - info = fopen("_info", "w"); + filename = talloc_asprintf(m, "%s/%s", m->dir, "_info"); + info = fopen(filename, "w"); if (!info) - err(1, "Trying to create a template _info"); + err(1, "Trying to create a template _info in %s", filename); if (fprintf(info, template, m->basename) < 0) { - unlink_noerr("_info"); - err(1, "Writing template into _info"); + unlink_noerr(filename); + err(1, "Writing template into %s", filename); } fclose(info); } struct ccanlint has_info = { - .name = "Has _info file", + .key = "info", + .name = "Module has _info file", .check = check_has_info, - .describe = describe_has_info, .handle = create_info_template, }; + +REGISTER_TEST(has_info, NULL);