Commit 27b8937c authored by Rusty Russell's avatar Rusty Russell

ccanlint: --compiler and --cflags options.

parent 104125b2
...@@ -43,8 +43,8 @@ static struct btree *info_exclude; ...@@ -43,8 +43,8 @@ static struct btree *info_exclude;
static unsigned int timeout; static unsigned int timeout;
/* These are overridden at runtime if we can find config.h */ /* These are overridden at runtime if we can find config.h */
const char *compiler = CCAN_COMPILER; char *compiler = NULL;
const char *cflags = CCAN_CFLAGS; char *cflags = NULL;
const char *config_header; const char *config_header;
...@@ -552,20 +552,28 @@ static void read_config_header(void) ...@@ -552,20 +552,28 @@ static void read_config_header(void)
if (!get_token(line, "define")) if (!get_token(line, "define"))
continue; continue;
sym = get_symbol_token(lines, line); sym = get_symbol_token(lines, line);
if (streq(sym, "CCAN_COMPILER")) { if (streq(sym, "CCAN_COMPILER") && !compiler) {
compiler = demangle_string(lines[i]); compiler = demangle_string(lines[i]);
if (!compiler)
errx(1, "%s:%u:could not parse CCAN_COMPILER",
fname, i+1);
if (verbose > 1) if (verbose > 1)
printf("%s: compiler set to '%s'\n", printf("%s: compiler set to '%s'\n",
fname, compiler); fname, compiler);
} else if (streq(sym, "CCAN_CFLAGS")) { } else if (streq(sym, "CCAN_CFLAGS") && !cflags) {
cflags = demangle_string(lines[i]); cflags = demangle_string(lines[i]);
if (!cflags)
errx(1, "%s:%u:could not parse CCAN_CFLAGS",
fname, i+1);
if (verbose > 1) if (verbose > 1)
printf("%s: compiler flags set to '%s'\n", printf("%s: compiler flags set to '%s'\n",
fname, cflags); fname, cflags);
} }
} }
if (!compiler || !cflags) if (!compiler)
errx(1, "Problem parsing %s", fname); compiler = CCAN_COMPILER;
if (!cflags)
compiler = CCAN_CFLAGS;
} }
int main(int argc, char *argv[]) int main(int argc, char *argv[])
...@@ -605,6 +613,10 @@ int main(int argc, char *argv[]) ...@@ -605,6 +613,10 @@ int main(int argc, char *argv[])
opt_register_arg("--target <testname>", opt_set_charp, opt_register_arg("--target <testname>", opt_set_charp,
NULL, &target, NULL, &target,
"only run one test (and its prerequisites)"); "only run one test (and its prerequisites)");
opt_register_arg("--compiler <compiler>", opt_set_charp,
NULL, &compiler, "set the compiler");
opt_register_arg("--cflags <flags>", opt_set_charp,
NULL, &cflags, "set the compiler flags");
opt_register_noarg("-?|-h|--help", opt_usage_and_exit, opt_register_noarg("-?|-h|--help", opt_usage_and_exit,
"\nA program for checking and guiding development" "\nA program for checking and guiding development"
" of CCAN modules.", " of CCAN modules.",
......
...@@ -222,7 +222,7 @@ extern bool safe_mode; ...@@ -222,7 +222,7 @@ extern bool safe_mode;
extern const char *ccan_dir; extern const char *ccan_dir;
/* Compiler and CFLAGS, from config.h if available. */ /* Compiler and CFLAGS, from config.h if available. */
extern const char *compiler, *cflags; extern char *compiler, *cflags;
/* Contents of config.h (or NULL if not found) */ /* Contents of config.h (or NULL if not found) */
extern const char *config_header; extern const char *config_header;
......
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