[svn-commits] kpfleming: branch kpfleming/multimodule-build r114015 - /team/kpfleming/multi...

SVN commits to the Digium repositories svn-commits at lists.digium.com
Wed Apr 9 19:00:14 CDT 2008


Author: kpfleming
Date: Wed Apr  9 19:00:13 2008
New Revision: 114015

URL: http://svn.digium.com/view/asterisk?view=rev&rev=114015
Log:
yay! generation of moduleinfo and makeopts now works properly


Modified:
    team/kpfleming/multimodule-build/astbuild/Makefile.core

Modified: team/kpfleming/multimodule-build/astbuild/Makefile.core
URL: http://svn.digium.com/view/asterisk/team/kpfleming/multimodule-build/astbuild/Makefile.core?view=diff&rev=114015&r1=114014&r2=114015
==============================================================================
--- team/kpfleming/multimodule-build/astbuild/Makefile.core (original)
+++ team/kpfleming/multimodule-build/astbuild/Makefile.core Wed Apr  9 19:00:13 2008
@@ -39,6 +39,12 @@
 # lists of module names (all modules, using virtual names for modules that have them)
 all-mods-c :=
 all-mods-cc :=
+all-multi-mods = $(all-multi-mods-c) $(all-multi-mods-cc)
+all-single-mods = $(all-single-mods-c) $(all-single-mods-cc)
+all-multi-mods-c :=
+all-multi-mods-cc :=
+all-single-mods-c :=
+all-single-mods-cc :=
 
 # lists of module names (modules to build)
 mods-c-m = $(single-mods-c-m) $(multi-mods-c-m)
@@ -125,22 +131,28 @@
 
 all-mods := $(sort $(all-mods-c) $(all-mods-cc))
 
+# generate lists of all known modules, separated by source type and build type
+all-multi-mods-c := $(sort $(foreach mod,$(all-mods-c),$(if $($(mod)),$(mod))))
+all-multi-mods-cc := $(sort $(foreach mod,$(all-mods-cc),$(if $($(mod)),$(mod))))
+all-single-mods-c := $(filter-out $(all-multi-mods-c),$(all-mods-c))
+all-single-mods-cc := $(filter-out $(all-multi-mods-cc),$(all-mods-cc))
+
 # compute the list of modules that will be built as loadable
 #  (the subdirectory makefile will only ever specify the ones
 #   not to build at all, or to build as built-in)
 mods-m += $(filter-out $(mods-y) $(mods-n),$(all-mods))
 
 # generate the lists of multi-component modules to be built
-multi-mods-c-m := $(filter-out $(mods-y) $(mods-n),$(foreach mod,$(all-mods-c),$(if $($(mod)),$(mod))))
-multi-mods-c-y := $(filter-out $(mods-m) $(mods-n),$(foreach mod,$(all-mods-c),$(if $($(mod)),$(mod))))
-multi-mods-cc-m := $(filter-out $(mods-y) $(mods-n),$(foreach mod,$(all-mods-cc),$(if $($(mod)),$(mod))))
-multi-mods-cc-y := $(filter-out $(mods-m) $(mods-n),$(foreach mod,$(all-mods-cc),$(if $($(mod)),$(mod))))
+multi-mods-c-m := $(filter-out $(mods-y) $(mods-n),$(all-multi-mods-c))
+multi-mods-c-y := $(filter-out $(mods-m) $(mods-n),$(all-multi-mods-c))
+multi-mods-cc-m := $(filter-out $(mods-y) $(mods-n),$(all-multi-mods-cc))
+multi-mods-cc-y := $(filter-out $(mods-m) $(mods-n),$(all-multi-mods-cc))
 
 # generate the lists of single component modules to be built
-single-mods-c-m := $(filter-out $(mods-y) $(mods-n),$(foreach mod,$(all-mods-c),$(if $($(mod)),,$(mod))))
-single-mods-c-y := $(filter-out $(mods-m) $(mods-n),$(foreach mod,$(all-mods-c),$(if $($(mod)),,$(mod))))
-single-mods-cc-m := $(filter-out $(mods-y) $(mods-n),$(foreach mod,$(all-mods-cc),$(if $($(mod)),,$(mod))))
-single-mods-cc-y := $(filter-out $(mods-m) $(mods-n),$(foreach mod,$(all-mods-cc),$(if $($(mod)),,$(mod))))
+single-mods-c-m := $(filter-out $(mods-y) $(mods-n),$(all-single-mods-c))
+single-mods-c-y := $(filter-out $(mods-m) $(mods-n),$(all-single-mods-c))
+single-mods-cc-m := $(filter-out $(mods-y) $(mods-n),$(all-single-mods-cc))
+single-mods-cc-y := $(filter-out $(mods-m) $(mods-n),$(all-single-mods-cc))
 
 # generate the lists of multi-component module object files
 multi-objs-c-m := $(sort $(foreach mod,$(multi-mods-c-m),$($(mod))))
@@ -163,26 +175,34 @@
 #
 module-base = $(if $($(1)),$(basename $(firstword $($(1)))),$(1))
 
+# function: module-bases
+#
+# get the base files for a list of modules
+#
+module-bases = $(sort $(foreach mod,$(1),$(call module-base,$(mod))))
+
 # function: modname-multi
 #
 # get the module name that a component will be linked into
-modname-multi = $(sort $(foreach mod,$(multi-mods), $(if $(filter $*$(1), $($(mod))),$(mod))))
+modname-multi = $(sort $(foreach mod,$(all-multi-mods), $(if $(filter $*$(1), $($(mod))),$(mod))))
 
 # set a variable called 'modname' for every file that gets built, containing
 # the module name that the file being built is associated with, or will be
-# linked into
+# linked into; some of these lists are built for the entire list of all
+# known modules, and others are built only for the modules that will be
+# built
 #
 # first, for single component modules (the easy ones):
 $(single-objs-c): modname = $*
 $(single-objs-cc): modname = $*
-$(patsubst %.o,$(astbuild_dir)/%.moduleinfo,$(single-objs-c)): modname = $*
-$(patsubst %.oo,$(astbuild_dir)/%.moduleinfo,$(single-objs-cc)): modname = $*
+$(patsubst %,$(astbuild_dir)/%.moduleinfo,$(all-single-mods-c)): modname = $*
+$(patsubst %,$(astbuild_dir)/%.moduleinfo,$(all-single-mods-cc)): modname = $*
 
 # second, for multi-component modules:
 $(multi-objs-c): modname = $(call modname-multi,.o)
 $(multi-objs-cc): modname = $(call modname-multi,.oo)
-$(patsubst %.o,$(astbuild_dir)/%.moduleinfo,$(multi-objs-c)): modname = $(call modname-multi,.o)
-$(patsubst %.oo,$(astbuild_dir)/%.moduleinfo,$(multi-objs-cc)): modname = $(call modname-multi,.oo)
+$(patsubst %,$(astbuild_dir)/%.moduleinfo,$(call module-bases,$(all-multi-mods-c))): modname = $(call modname-multi,.o)
+$(patsubst %,$(astbuild_dir)/%.moduleinfo,$(call module-bases,$(all-multi-mods-cc))): modname = $(call modname-multi,.oo)
 
 $(astbuild_dir)/%.moduleinfo: %.c
 	@echo "<member name=\"$(modname)\" displayname=\"$(shell $(GREP) -e AST_MODULE_INFO $< | head -n 1 | cut -d '"' -f 2)\">" > $@
@@ -194,7 +214,7 @@
 	@$(AWK) -f $(ASTBUILD)/get_moduleinfo $< >> $@
 	@echo "</member>" >> $@
 
-$(astbuild_dir)/moduleinfo: $(astbuild_dir) $(addsuffix .moduleinfo,$(addprefix $(astbuild_dir)/,$(foreach mod,$(all-mods),$(call module-base,$(mod)))))
+$(astbuild_dir)/moduleinfo: $(astbuild_dir) $(patsubst %,$(astbuild_dir)/%.moduleinfo,$(call module-bases,$(all-mods)))
 	@echo "<category name=\"MENUSELECT_$(MENUSELECT_CATEGORY)\" displayname=\"$(MENUSELECT_DESCRIPTION)\" >" > $@
 	@cat $(filter-out $(astbuild_dir),$^) >> $@
 	@echo "</category>" >> $@
@@ -208,7 +228,7 @@
 $(astbuild_dir)/%.makeopts: %.cc
 	@$(AWK) -f $(ASTBUILD)/get_makeopts $< > $@
 
-$(astbuild_dir)/makeopts: $(astbuild_dir) $(addsuffix .makeopts,$(addprefix $(astbuild_dir)/,$(foreach mod,$(all-mods),$(call module-base,$(mod)))))
+$(astbuild_dir)/makeopts: $(astbuild_dir) $(patsubst %,$(astbuild_dir)/%.makeopts,$(call module-bases,$(all-mods)))
 	@cat $(filter-out $(astbuild_dir),$^) > $@
 
 makeopts: $(astbuild_dir)/makeopts




More information about the svn-commits mailing list