X-Git-Url: https://git.ozlabs.org/?p=ccan;a=blobdiff_plain;f=tools%2Ftools.h;h=e78d13904c82b1c36c263ddb57a5fdb267779139;hp=a4c4cfa06b8f3bd79ff3b5e7ed274143b8634c51;hb=e2a53df3e1f5912c872f1906912053354d0d0c63;hpb=1f45ec04761cd99011445c6d41cd64a3951f77e0 diff --git a/tools/tools.h b/tools/tools.h index a4c4cfa0..e78d1390 100644 --- a/tools/tools.h +++ b/tools/tools.h @@ -19,13 +19,15 @@ #define COVERAGE_CFLAGS "-fprofile-arcs -ftest-coverage" +/* 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_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, bool recurse); /* This also needs to compile the info file. */ char **get_libs(const void *ctx, const char *dir, @@ -43,7 +45,7 @@ bool PRINTF_FMT(4,5) run_command(const void *ctx, 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. @@ -54,20 +56,21 @@ 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 *basename, bool in_pwd, +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 *extra_cflags, + 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 *extra_cflags, + 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, - const char *srcname); +/* 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; @@ -75,4 +78,6 @@ 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 */