X-Git-Url: http://git.ozlabs.org/?p=ccan;a=blobdiff_plain;f=tools%2Ftools.h;h=7e2598c3167559df675c71df2f9d6ebcf624464a;hp=a7a25c99cd756e0c68dedc9da2247c7be0ad7371;hb=608148436caa82ffe78d758253c6b7eb5232cb70;hpb=a1d06d55999cc5004f4a3c2c8c17638972c6fe50 diff --git a/tools/tools.h b/tools/tools.h index a7a25c99..7e2598c3 100644 --- a/tools/tools.h +++ b/tools/tools.h @@ -1,43 +1,72 @@ #ifndef CCAN_TOOLS_H #define CCAN_TOOLS_H +#include "config.h" +#include +#include +#include +#include +#include #include +/* These are the defaults. */ +#define DEFAULT_CCAN_COMPILER "cc" +#define DEFAULT_CCAN_CFLAGS "-g" + #define IDENT_CHARS "ABCDEFGHIJKLMNOPQRSTUVWXYZ" \ "abcdefghijklmnopqrstuvwxyz" \ "01234567889_" #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" +/* Actual compiler and cflags (defaults to CCAN_COMPILER and CCAN_CFLAGS). */ +extern const char *compiler, *cflags; + +/* This compiles up the _info file into a temporary. */ +char *compile_info(const void *ctx, const char *dir); + /* This actually compiles and runs the info file to get dependencies. */ -char **get_deps(const void *ctx, const char *dir, bool recurse, - char **infofile); +char **get_deps(const void *ctx, const char *dir, const char *style, + bool recurse, + char *(*get_info)(const void *ctx, const char *dir)); /* 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, const char *style, + bool recurse); + +/* This also needs to compile the info file: + * style == NULL: don't recurse. + * style == depends: recurse dependencies. + * style == testdepends: recurse testdepends and depends. + */ +char **get_libs(const void *ctx, const char *dir, const char *style, + char *(*get_info)(const void *ctx, const char *dir)); + +char **get_cflags(const void *ctx, const char *dir, + char *(*get_info)(const void *ctx, const char *dir)); -/* This also needs to compile the info file. */ -char **get_libs(const void *ctx, const char *dir, - unsigned int *num, char **infofile); +bool get_ported(const void *ctx, const char *dir, bool recurse, + char *(*get_info)(const void *ctx, const char *dir)); /* 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, 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); -char *temp_file(const void *ctx, const char *extension); +const char *temp_dir(void); +void keep_temp_dir(void); bool move_file(const char *oldname, const char *newname); +void *do_tal_realloc(void *p, size_t size); + +/* Freed on exit: a good parent for auto cleanup. */ +tal_t *autofree(void); + /* From compile.c. * * These all compile into a temporary dir, and return the filename. @@ -46,22 +75,25 @@ 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); -/* 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); - -/* 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); +char *link_objects(const void *ctx, const char *basename, + const char *objs, char **errmsg); +/* 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); + +/* Returns a file in temp_dir() */ +char *temp_file(const void *ctx, const char *extension, const char *srcname); /* Default wait for run_command. Should never time out. */ extern const unsigned int default_timeout_ms; +/* Get ccan/ top dir, given a directory within it. */ +const char *find_ccan_dir(const char *base); #endif /* CCAN_TOOLS_H */