X-Git-Url: http://git.ozlabs.org/?p=ccan;a=blobdiff_plain;f=tools%2Ftools.h;h=60707499efcf559b2848d1778763eeba809ffa67;hp=56e9de610620a0c944da84fc7f58337c3ae66393;hb=77354575335e5ee900a4ba126d4d76e34b9273e8;hpb=fa7a78f9d3553292b5088b1e7a89d63a2393ab2c diff --git a/tools/tools.h b/tools/tools.h index 56e9de61..60707499 100644 --- a/tools/tools.h +++ b/tools/tools.h @@ -1,15 +1,16 @@ #ifndef CCAN_TOOLS_H #define CCAN_TOOLS_H -#include -#include #include "config.h" +#include +#include +#include +#include +#include +#include -#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 +/* These are the defaults. */ +#define DEFAULT_CCAN_COMPILER "cc" +#define DEFAULT_CCAN_CFLAGS "-g" #define IDENT_CHARS "ABCDEFGHIJKLMNOPQRSTUVWXYZ" \ "abcdefghijklmnopqrstuvwxyz" \ @@ -19,35 +20,48 @@ #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 **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 **get_safe_ccan_deps(const void *ctx, const char *dir, const char *style, + bool recurse); -/* This also needs to compile the info file. */ -char **get_libs(const void *ctx, const char *dir, 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)); /* 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); 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); -const char *temp_dir(const void *ctx); +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); +void *tal_grab_file(const void *ctx, const char *filename, 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. @@ -75,9 +89,6 @@ 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; -/* Talloc destructor which unlinks file. */ -int unlink_file_destructor(char *filename); - /* Get ccan/ top dir, given a directory within it. */ const char *find_ccan_dir(const char *base); #endif /* CCAN_TOOLS_H */