makedep: Generate a common rule for all objects of a given idl source.

This commit is contained in:
Alexandre Julliard 2013-12-24 21:12:08 +01:00
parent 9e307f268e
commit d7afa57597
1 changed files with 12 additions and 11 deletions

View File

@ -66,17 +66,16 @@ static const struct
{ {
unsigned int flag; unsigned int flag;
const char *ext; const char *ext;
const char *widl_arg;
} idl_outputs[] = } idl_outputs[] =
{ {
{ FLAG_IDL_TYPELIB, ".tlb", "$(TARGETFLAGS) $(IDLFLAGS) -t" }, { FLAG_IDL_TYPELIB, ".tlb" },
{ FLAG_IDL_REGTYPELIB, "_t.res", "$(TARGETFLAGS) $(IDLFLAGS) -t" }, { FLAG_IDL_REGTYPELIB, "_t.res" },
{ FLAG_IDL_CLIENT, "_c.c", "$(IDLFLAGS) -c" }, { FLAG_IDL_CLIENT, "_c.c" },
{ FLAG_IDL_IDENT, "_i.c", "$(IDLFLAGS) -u" }, { FLAG_IDL_IDENT, "_i.c" },
{ FLAG_IDL_PROXY, "_p.c", "$(IDLFLAGS) -p" }, { FLAG_IDL_PROXY, "_p.c" },
{ FLAG_IDL_SERVER, "_s.c", "$(IDLFLAGS) -s" }, { FLAG_IDL_SERVER, "_s.c" },
{ FLAG_IDL_REGISTER, "_r.res", "$(IDLFLAGS) -r" }, { FLAG_IDL_REGISTER, "_r.res" },
{ FLAG_IDL_HEADER, ".h", "$(IDLFLAGS) -h" }, { FLAG_IDL_HEADER, ".h" }
}; };
static struct list sources = LIST_INIT(sources); static struct list sources = LIST_INIT(sources);
@ -1468,14 +1467,16 @@ static struct strarray output_sources(void)
for (i = 0; i < sizeof(idl_outputs) / sizeof(idl_outputs[0]); i++) for (i = 0; i < sizeof(idl_outputs) / sizeof(idl_outputs[0]); i++)
{ {
if (!(source->flags & idl_outputs[i].flag)) continue; if (!(source->flags & idl_outputs[i].flag)) continue;
output( "%s%s: $(WIDL)\n", obj, idl_outputs[i].ext );
output( "\t$(WIDL) $(includes) %s -o $@ %s\n", idl_outputs[i].widl_arg, source->filename );
dest = strmake( "%s%s", obj, idl_outputs[i].ext ); dest = strmake( "%s%s", obj, idl_outputs[i].ext );
strarray_add( &clean_files, dest ); strarray_add( &clean_files, dest );
strarray_add( &targets, dest ); strarray_add( &targets, dest );
} }
column = 0; column = 0;
output_filenames( &targets, &column ); output_filenames( &targets, &column );
output( ": $(WIDL)\n" );
output( "\t$(WIDL) $(includes) $(TARGETFLAGS) $(IDLFLAGS) -o $@ %s\n", source->filename );
column = 0;
output_filenames( &targets, &column );
column += output( ": %s", sourcedep ); column += output( ": %s", sourcedep );
} }
else if (!strcmp( ext, "in" )) /* .in file or man page */ else if (!strcmp( ext, "in" )) /* .in file or man page */