X-Git-Url: https://git.ozlabs.org/?p=ccan;a=blobdiff_plain;f=tools%2Ftools.h;h=168a47bd28e0c595b3162c1c58d6a376d428c524;hp=a7a25c99cd756e0c68dedc9da2247c7be0ad7371;hb=d3104024f71cf4f89195787add6c7ac381d62f40;hpb=a1d06d55999cc5004f4a3c2c8c17638972c6fe50 diff --git a/tools/tools.h b/tools/tools.h index a7a25c99..168a47bd 100644 --- a/tools/tools.h +++ b/tools/tools.h @@ -1,6 +1,14 @@ #ifndef CCAN_TOOLS_H #define CCAN_TOOLS_H #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,9 +16,6 @@ #define SPACE_CHARS " \f\n\r\t\v" -/* FIXME: Nested functions break with -Wmissing-prototypes -Wmissing-declarations */ -#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. */ @@ -35,7 +40,6 @@ 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. @@ -46,7 +50,8 @@ bool move_file(const char *oldname, const char *newname); /* If set, say what we're compiling to. */ extern bool compile_verbose; /* Compile multiple object files into a single. */ -char *link_objects(const void *ctx, const char *objs, char **errmsg); +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, @@ -57,8 +62,8 @@ 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, +/* 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, const char *srcname); /* Default wait for run_command. Should never time out. */