X-Git-Url: https://git.ozlabs.org/?p=ccan;a=blobdiff_plain;f=tools%2Ftools.h;h=f3e132d97a37110c92da61ba48d3f82e7c46f3e8;hp=0ea4a6cdcdc6c26b84f436e9f3036cb2a9f3b509;hb=03c49198146e11e579a7bbc4d9df27cc71dba034;hpb=4d98de9875710da8b1951cc0b22bcd7f87a9ee45 diff --git a/tools/tools.h b/tools/tools.h index 0ea4a6cd..f3e132d9 100644 --- a/tools/tools.h +++ b/tools/tools.h @@ -1,6 +1,15 @@ #ifndef CCAN_TOOLS_H #define CCAN_TOOLS_H #include +#include +#include "config.h" + +#ifndef CCAN_COMPILER +#define CCAN_COMPILER "cc" +#endif +#ifndef CCAN_CFLAGS +#define CCAN_CFLAGS "-g -Wall -Wundef -Wmissing-prototypes -Wmissing-declarations -Wstrict-prototypes -Wold-style-definition -Werror" +#endif #define IDENT_CHARS "ABCDEFGHIJKLMNOPQRSTUVWXYZ" \ "abcdefghijklmnopqrstuvwxyz" \ @@ -8,8 +17,6 @@ #define SPACE_CHARS " \f\n\r\t\v" -#define CFLAGS "-g -Wall -Wundef -Wmissing-prototypes -Wmissing-declarations -Wstrict-prototypes -Wold-style-definition -Werror" - #define COVERAGE_CFLAGS "-fprofile-arcs -ftest-coverage" /* This actually compiles and runs the info file to get dependencies. */ @@ -17,8 +24,7 @@ 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, - bool recurse, char **infofile); +char **get_safe_ccan_deps(const void *ctx, const char *dir, bool recurse); /* This also needs to compile the info file. */ char **get_libs(const void *ctx, const char *dir, @@ -30,10 +36,13 @@ 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, unsigned int *time_ms, const char *fmt, ...); +bool PRINTF_FMT(4,5) run_command(const void *ctx, + unsigned int *time_ms, + char **output, + const char *fmt, ...); char *run_with_timeout(const void *ctx, const char *cmd, bool *ok, unsigned *timeout_ms); -char *temp_dir(const void *ctx); +const char *temp_dir(const void *ctx); bool move_file(const char *oldname, const char *newname); /* From compile.c. @@ -46,15 +55,16 @@ extern bool compile_verbose; /* Compile multiple object files into a single. */ char *link_objects(const void *ctx, const char *basename, bool in_pwd, 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, 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); +/* Compile a single C file to an object file. Returns false if fails. */ +bool compile_object(const void *ctx, const char *cfile, const char *ccandir, + const char *compiler, + const char *cflags, + const char *outfile, char **output); +/* Compile and link single C file, with object files, libs, etc. */ +bool compile_and_link(const void *ctx, const char *cfile, const char *ccandir, + const char *objs, + const char *compiler, const char *cflags, + const char *libs, const char *outfile, char **output); /* If in_pwd is false, return a file int temp_dir, otherwise a local file. */ char *maybe_temp_file(const void *ctx, const char *extension, bool in_pwd, @@ -63,4 +73,7 @@ char *maybe_temp_file(const void *ctx, const char *extension, bool in_pwd, /* Default wait for run_command. Should never time out. */ extern const unsigned int default_timeout_ms; +/* Talloc destructor which unlinks file. */ +int unlink_file_destructor(char *filename); + #endif /* CCAN_TOOLS_H */