X-Git-Url: https://git.ozlabs.org/?a=blobdiff_plain;f=tools%2Fccanlint%2Fcompulsory_tests%2Fcheck_includes_build.c;h=cc5edc4ccaabbf2525b9072a4e64da3ceef6d02f;hb=83cfe17fd85efb7f5d8e8b1edb1f3c28b180a2ce;hp=b3e4ee682b87ce1db21cbfd9654229f80c796caa;hpb=fb4c4c3ddc24772f71a64ec02d2c9ddaeb6e9f6b;p=ccan diff --git a/tools/ccanlint/compulsory_tests/check_includes_build.c b/tools/ccanlint/compulsory_tests/check_includes_build.c index b3e4ee68..cc5edc4c 100644 --- a/tools/ccanlint/compulsory_tests/check_includes_build.c +++ b/tools/ccanlint/compulsory_tests/check_includes_build.c @@ -32,12 +32,12 @@ static struct ccan_file *main_header(struct manifest *m) return f; } /* Should not happen: we depend on has_main_header */ - return NULL; + abort(); } -static void *check_includes_build(struct manifest *m, - bool keep, - unsigned int *timeleft) +static void check_includes_build(struct manifest *m, + bool keep, + unsigned int *timeleft, struct score *score) { char *contents; char *tmpsrc, *tmpobj; @@ -49,34 +49,29 @@ static void *check_includes_build(struct manifest *m, fd = open(tmpsrc, O_WRONLY | O_CREAT | O_EXCL, 0600); if (fd < 0) - return talloc_asprintf(m, "Creating temporary file %s: %s", - tmpsrc, strerror(errno)); + err(1, "Creating temporary file %s", tmpsrc); contents = talloc_asprintf(tmpsrc, "#include \n", m->basename, m->basename); - if (write(fd, contents, strlen(contents)) != strlen(contents)) { - close(fd); - return "Failure writing to temporary file"; - } + if (write(fd, contents, strlen(contents)) != strlen(contents)) + err(1, "writing to temporary file %s", tmpsrc); close(fd); - return compile_object(m, tmpsrc, ccan_dir, tmpobj); -} - -static const char *describe_includes_build(struct manifest *m, - void *check_result) -{ - return talloc_asprintf(check_result, - "#include of the main header file:\n" - "%s", (char *)check_result); + score->error = compile_object(m, tmpsrc, ccan_dir, "", tmpobj); + if (score->error) { + score->error = talloc_asprintf(score, + "#include of the main header file:\n%s", + score->error); + } else { + score->pass = true; + score->score = score->total; + } } struct ccanlint includes_build = { .key = "include-main", .name = "Modules main header compiles", - .total_score = 1, .check = check_includes_build, - .describe = describe_includes_build, .can_run = can_build, };