X-Git-Url: https://git.ozlabs.org/?p=ccan;a=blobdiff_plain;f=tools%2Ftools.h;h=9430d01671054627eb48789c6ddb2feca8f7aff6;hp=ed2f6bfb6e77442e9682f450d34db6b2cce6e93e;hb=32710c917e41b6a283ab73190614623c1a8e9508;hpb=009f261242b7e1f5482e097315c82a4185a708bf diff --git a/tools/tools.h b/tools/tools.h index ed2f6bfb..9430d016 100644 --- a/tools/tools.h +++ b/tools/tools.h @@ -8,28 +8,35 @@ #define SPACE_CHARS " \f\n\r\t\v" -/* FIXME: Remove some -I */ /* FIXME: Nested functions break with -Wmissing-prototypes -Wmissing-declarations */ -#define CFLAGS "-g -Wall -Wundef -Wstrict-prototypes -Wold-style-definition -Werror -Iccan/ -I. -I.. -I../.." +#define CFLAGS "-g -Wall -Wundef -Wstrict-prototypes -Wold-style-definition -Werror" + +#define COVERAGE_CFLAGS "-fprofile-arcs -ftest-coverage" /* This actually compiles and runs the info file to get dependencies. */ -char **get_deps(const void *ctx, const char *dir, const char *name, - bool recurse, char **infofile); +char **get_deps(const void *ctx, const char *dir, bool recurse, + char **infofile); /* This is safer: just looks for ccan/ strings in info */ -char **get_safe_ccan_deps(const void *ctx, const char *dir, const char *name, +char **get_safe_ccan_deps(const void *ctx, const char *dir, bool recurse, char **infofile); /* This also needs to compile the info file. */ char **get_libs(const void *ctx, const char *dir, - const char *name, unsigned int *num, char **infofile); + unsigned int *num, char **infofile); /* From tools.c */ +/* If set, print all commands run, all output they give and exit status. */ +extern bool tools_verbose; char *talloc_basename(const void *ctx, const char *dir); char *talloc_dirname(const void *ctx, const char *dir); char *talloc_getcwd(const void *ctx); -char *run_command(const void *ctx, const char *fmt, ...); +char *run_command(const void *ctx, unsigned int *time_ms, const char *fmt, ...); +char *run_with_timeout(const void *ctx, const char *cmd, + bool *ok, unsigned *timeout_ms); +char *temp_dir(const void *ctx); char *temp_file(const void *ctx, const char *extension); +bool move_file(const char *oldname, const char *newname); /* From compile.c. * @@ -39,9 +46,20 @@ char *temp_file(const void *ctx, const char *extension); /* Compile multiple object files into a single. */ char *link_objects(const void *ctx, const char *objs, char **errmsg); /* Compile a single C file to an object file. Returns errmsg if fails. */ -char *compile_object(const void *ctx, const char *cfile, char **errmsg); -/* Compile and link single C file, with object files, libs, etc. */ -char *compile_and_link(const void *ctx, const char *cfile, const char *objs, - const char *extra_cflags, const char *libs, - char **errmsg); +char *compile_object(const void *ctx, const char *cfile, const char *ccandir, + const char *extra_cflags, + const char *outfile); +/* Compile and link single C file, with object files, libs, etc. NULL on + * success, error output on fail. */ +char *compile_and_link(const void *ctx, const char *cfile, const char *ccandir, + const char *objs, const char *extra_cflags, + const char *libs, const char *outfile); + +/* If keep is false, return a temporary file. Otherwise, base it on srcname */ +char *maybe_temp_file(const void *ctx, const char *extension, bool keep, + const char *srcname); + +/* Default wait for run_command. Should never time out. */ +extern const unsigned int default_timeout_ms; + #endif /* CCAN_TOOLS_H */