X-Git-Url: http://git.ozlabs.org/?p=ccan;a=blobdiff_plain;f=tools%2Ftools.h;h=babd30c9370892c2f6961f3546bf493d94f1ec43;hp=34c2f99ff1253fe38a888fe697c79f9bb07fb323;hb=fb4c4c3ddc24772f71a64ec02d2c9ddaeb6e9f6b;hpb=354c772e913d137034d5bcd00efdcb880697532e diff --git a/tools/tools.h b/tools/tools.h index 34c2f99f..babd30c9 100644 --- a/tools/tools.h +++ b/tools/tools.h @@ -27,7 +27,7 @@ char **get_libs(const void *ctx, const char *dir, 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, const char *fmt, ...); +char *run_command(const void *ctx, unsigned int *time_ms, const char *fmt, ...); char *temp_file(const void *ctx, const char *extension); bool move_file(const char *oldname, const char *newname); @@ -40,9 +40,18 @@ 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; + #endif /* CCAN_TOOLS_H */