X-Git-Url: http://git.ozlabs.org/?p=ccan;a=blobdiff_plain;f=tools%2Ftools.h;h=5f5f119dfaa6d20e8ed5b46fe990681be9edacdd;hp=c311809eed446a5dabaad171fe87eb46f3743b9e;hb=32a31d9e4fb1f312a47ae8c237ac30d6c1567ccd;hpb=3612661714e86333ceacca7314959a5ed938dc6a diff --git a/tools/tools.h b/tools/tools.h index c311809e..5f5f119d 100644 --- a/tools/tools.h +++ b/tools/tools.h @@ -8,8 +8,8 @@ #define SPACE_CHARS " \f\n\r\t\v" -/* FIXME: Remove some -I */ -#define CFLAGS "-O -Wall -Wundef -Wstrict-prototypes -Wold-style-definition -Wmissing-prototypes -Wmissing-declarations -Werror -Iccan/ -I.. -I../.." +/* FIXME: Nested functions break with -Wmissing-prototypes -Wmissing-declarations */ +#define CFLAGS "-g -Wall -Wundef -Wstrict-prototypes -Wold-style-definition -Werror -I../.." /* This actually compiles and runs the info file to get dependencies. */ char **get_deps(const void *ctx, const char *dir, const char *name, @@ -30,13 +30,16 @@ char *talloc_getcwd(const void *ctx); char *run_command(const void *ctx, const char *fmt, ...); char *temp_file(const void *ctx, const char *extension); -/* From compile.c. */ -/* Compile multiple object files into a single. Returns errmsg if fails. */ -char *link_objects(const void *ctx, const char *outfile, const char *objs); +/* From compile.c. + * + * These all compile into a temporary dir, and return the filename. + * On failure they return NULL, and errmsg is set to compiler output. + */ +/* 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 *outfile, const char *cfile); -/* Compile and link single C file, with object files. - * Returns name of result, or NULL (and fills in errmsg). */ +char *compile_object(const void *ctx, const char *cfile, char **errmsg); +/* Compile and link single C file, with object files, libs, etc. */ char *compile_and_link(const void *ctx, const char *cfile, const char *objs, const char *extra_cflags, const char *libs, char **errmsg);