X-Git-Url: http://git.ozlabs.org/?p=ccan;a=blobdiff_plain;f=tools%2Ftools.h;h=babd30c9370892c2f6961f3546bf493d94f1ec43;hp=9a4082db63caf35a04b218ee42b4c1812476a58c;hb=fb4c4c3ddc24772f71a64ec02d2c9ddaeb6e9f6b;hpb=1d893107b3481639bf1fc6f96972457ac6e828f7 diff --git a/tools/tools.h b/tools/tools.h index 9a4082db..babd30c9 100644 --- a/tools/tools.h +++ b/tools/tools.h @@ -40,11 +40,16 @@ bool move_file(const char *oldname, const char *newname); 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, - char **errmsg); -/* Compile and link single C file, with object files, libs, etc. */ + 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, char **errmsg); + 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); /* Default wait for run_command. Should never time out. */ extern const unsigned int default_timeout_ms;