[ccan] [PATCH 8/9] configurator: Pass output cflag to configurator
David Gibson
david at gibson.dropbear.id.au
Tue Sep 20 15:23:59 AEST 2016
On Sun, Sep 18, 2016 at 06:52:05PM -0600, Kevin Locke wrote:
> Unfortunately, not all compilers support -o as a command-line option for
> specifying the output file. Visual Studio cl.exe issues warning D9035
> when -o is given, which is detected as a compile warning by the
> configurator.
>
> To support such compilers, pass the output flag as the last flag to the
> configurator.
>
> This is a breaking change. Existing scripts which pass flags to the
> compiler must be modified to add "-o" as the last flag. As noted in the
> cover letter for this patch series, I'm open to considering alternatives
> if this is unacceptable.
>
> Signed-off-by: Kevin Locke <kevin at kevinlocke.name>
So, as it stands, this change completely breaks ccanlint on POSIX,
which is not ok. Specifically it looks like the problem is that the
DEFAULT_FLAGS from the configurator make it into CCAN_CFLAGS in
config.h. ccanlint then tries to add further options and its own -o
to the end of that, which isn't going to work.
In short, I think the problem is that ccanlint needs fixes to work
with MSVC (and possibly anything much else apart from gcc). I think
we need to look at how to fix that and the configurator together with
each other.
Not having working ccanlint on Windows seems like a pretty big, since
its the main tool for testing ccan, amongst other things.
> ---
> Makefile | 2 +-
> tools/configurator/configurator.c | 6 +++---
> 2 files changed, 4 insertions(+), 4 deletions(-)
>
> diff --git a/Makefile b/Makefile
> index 127b875..f36ccb5 100644
> --- a/Makefile
> +++ b/Makefile
> @@ -89,7 +89,7 @@ FORCE:
>
> # Ensure we don't end up with empty file if configurator fails!
> config.h: tools/configurator/configurator Makefile Makefile-ccan
> - tools/configurator/configurator $(CC) $(CCAN_CFLAGS) > $@.tmp && mv $@.tmp $@
> + tools/configurator/configurator $(CC) $(CCAN_CFLAGS) -o > $@.tmp && mv $@.tmp $@
>
> include tools/Makefile
> -include inter-depends
> diff --git a/tools/configurator/configurator.c b/tools/configurator/configurator.c
> index 0c30aff..820ccf7 100644
> --- a/tools/configurator/configurator.c
> +++ b/tools/configurator/configurator.c
> @@ -36,7 +36,7 @@
> #endif
>
> #define DEFAULT_COMPILER "cc"
> -#define DEFAULT_FLAGS "-g3 -ggdb -Wall -Wundef -Wmissing-prototypes -Wmissing-declarations -Wstrict-prototypes -Wold-style-definition"
> +#define DEFAULT_FLAGS "-g3 -ggdb -Wall -Wundef -Wmissing-prototypes -Wmissing-declarations -Wstrict-prototypes -Wold-style-definition -o"
>
> #define OUTPUT_FILE "configurator.out"
> #define INPUT_FILE "configuratortest.c"
> @@ -672,7 +672,7 @@ int main(int argc, const char *argv[])
> if (argc > 1) {
> if (strcmp(argv[1], "--help") == 0) {
> printf("Usage: configurator [-v] [<compiler> <flags>...]\n"
> - " <compiler> <flags> will have \"-o <outfile> <infile.c>\" appended\n"
> + " <compiler> <flags> will have \"<outfile> <infile.c>\" appended\n"
> "Default: %s %s\n",
> DEFAULT_COMPILER, DEFAULT_FLAGS);
> exit(0);
> @@ -691,7 +691,7 @@ int main(int argc, const char *argv[])
> if (argc == 1)
> argv = default_args;
>
> - cmd = connect_args(argv, " -o " OUTPUT_FILE " " INPUT_FILE);
> + cmd = connect_args(argv, OUTPUT_FILE " " INPUT_FILE);
> for (i = 0; i < sizeof(tests)/sizeof(tests[0]); i++)
> run_test(cmd, &tests[i]);
> free(cmd);
--
David Gibson | I'll have my music baroque, and my code
david AT gibson.dropbear.id.au | minimalist, thank you. NOT _the_ _other_
| _way_ _around_!
http://www.ozlabs.org/~dgibson
-------------- next part --------------
A non-text attachment was scrubbed...
Name: signature.asc
Type: application/pgp-signature
Size: 819 bytes
Desc: not available
URL: <http://lists.ozlabs.org/pipermail/ccan/attachments/20160920/415dd225/attachment.sig>
More information about the ccan
mailing list