I needed to increment the numbers used on the VERBOSITY_ATLEAST calls by 1.
[asterisk/asterisk.git] / Makefile.rules
index 5a0153e..ca21dcc 100644 (file)
 # the GNU General Public License
 #
 
-ifeq ($(NOISY_BUILD),)
+# Rules for various build phases.
+# Each command is preceded by a short comment on what to do.
+# Prefixing one or the other with @\# or @ or nothing makes the desired
+# behaviour. ECHO_PREFIX prefixes the comment, CMD_PREFIX prefixes the command.
+
+-include $(ASTTOPDIR)/makeopts
+
+.PHONY: dist-clean
 
-define ast_make_o_c
-$(1): $(2)
-       @echo "   [CC] $$< -> $$@"
-       @$$(CC) -o $$@ -c $$< $$(CFLAGS)
-endef
-
-define ast_make_oo_cc
-$(1): $(2)
-       @echo "   [CXX] $$< -> $$@"
-       @$$(CXX) -o $$@ -c $$< $$(CFLAGS)
-endef
-
-define ast_make_c_y
-$(1): $(2)
-       @echo "   [BISON] $$< -> $$@"
-       @bison -o $$@ -d --name-prefix=ast_yy $$<
-endef
-
-define ast_make_c_fl
-$(1): $(2)
-       @echo "   [FLEX] $$< -> $$@"
-       @flex -o $$@ --full $$<
-endef
-
-define ast_make_so_o
-$(1): $(2)
-       @echo "   [LD] $$^ -> $$@"
-       @$$(CC) -o $$@ $$(SOLINK) $$^ $$(LDFLAGS)
-endef
-
-define ast_make_so_oo
-$(1): $(2)
-       @echo "   [LDXX] $$^ -> $$@"
-       @$$(CXX) -o $$@ $$(SOLINK) $$^ $$(LDFLAGS)
-endef
-
-define ast_make_a_o
-$(1): $(2)
-       @echo "   [AR] $$^ -> $$@"
-       @$$(AR) cr $$@ $$^
-       @$$(RANLIB) $$@
-endef
-
-define ast_make_final
-$(1): $(2)
-       @echo "   [LD] $$^ -> $$@"
-       @$$(CC) -o $$@ $$^ $$(LDFLAGS)
-endef
-
-define ast_make_final_host
-$(1): $(2)
-       @echo "   [LD] $$^ -> $$@"
-       @$$(HOST_CC) -o $$@ $$^ $$(CFLAGS) $$(LDFLAGS)
-endef
+# extra cflags to build dependencies. Recursively expanded.
+MAKE_DEPS= -MMD -MT $@ -MF .$(subst /,_,$@).d -MP
 
+ifeq ($(NOISY_BUILD),)
+    ECHO_PREFIX=@
+    CMD_PREFIX=@
 else
+    ECHO_PREFIX=@\#
+    CMD_PREFIX=
+endif
 
-define ast_make_o_c
-$(1): $(2)
-       $$(CC) -o $$@ -c $$< $$(CFLAGS)
-endef
-
-define ast_make_oo_cc
-$(1): $(2)
-       $$(CXX) -o $$@ -c $$< $$(CFLAGS)
-endef
-
-define ast_make_c_y
-$(1): $(2)
-       bison -o $$@ -d --name-prefix=ast_yy $$<
-endef
-
-define ast_make_c_fl
-$(1): $(2)
-       flex -o $$@ --full $$<
-endef
-
-define ast_make_so_o
-$(1): $(2)
-       $$(CC) -o $$@ $$(SOLINK) $$^ $$(LDFLAGS)
-endef
-
-define ast_make_so_oo
-$(1): $(2)
-       $$(CXX) -o $$@ $$(SOLINK) $$^ $$(LDFLAGS)
-endef
-
-define ast_make_a_o
-$(1): $(2)
-       $$(AR) cr $$@ $$^
-       $$(RANLIB) $$@
-endef
-
-define ast_make_final
-$(1): $(2)
-       $$(CC) -o $$@ $$^ $$(LDFLAGS)
-endef
-
-define ast_make_final_host
-$(1): $(2)
-       $$(HOST_CC) -o $$@ $$^ $$(CFLAGS) $$(LDFLAGS)
-endef
+ifeq ($(findstring DONT_OPTIMIZE,$(MENUSELECT_CFLAGS)),)
+    # More GSM codec optimization
+    # Uncomment to enable MMXTM optimizations for x86 architecture CPU's
+    # which support MMX instructions.  This should be newer pentiums,
+    # ppro's, etc, as well as the AMD K6 and K7.  
+    #K6OPT=-DK6OPT
 
+    OPTIMIZE?=-O6
+    ASTCFLAGS+=$(OPTIMIZE)
 endif
 
-$(eval $(call ast_make_o_c,%.o,%.c))
+# build rules for various targets
+%.o: %.c
+       $(ECHO_PREFIX) echo "   [CC] $< -> $@"
+       $(CMD_PREFIX) $(CC) -o $@ -c $< $(PTHREAD_CFLAGS) $(ASTCFLAGS) $(MAKE_DEPS)
+
+%.o: %.i
+       $(ECHO_PREFIX) echo "   [CCi] $< -> $@"
+       $(CMD_PREFIX) $(CC) -o $@ -c $< $(PTHREAD_CFLAGS) $(ASTCFLAGS) $(MAKE_DEPS)
+
+%.i: %.c
+       $(ECHO_PREFIX) echo "   [CPP] $< -> $@"
+       $(CMD_PREFIX) $(CC) -o $@ -E $< $(PTHREAD_CFLAGS) $(ASTCFLAGS) $(MAKE_DEPS)
+
+%.o: %.s
+       $(ECHO_PREFIX) echo "   [AS] $< -> $@"
+       $(CMD_PREFIX) $(CC) -o $@ -c $< $(PTHREAD_CFLAGS) $(ASTCFLAGS) $(MAKE_DEPS)
+
+%.oo: %.cc
+       $(ECHO_PREFIX) echo "   [CXX] $< -> $@"
+       $(CMD_PREFIX) $(CXX) -o $@ -c $< $(PTHREAD_CFLAGS) $(filter-out -Wstrict-prototypes -Wmissing-prototypes -Wmissing-declarations,$(ASTCFLAGS)) $(MAKE_DEPS)
+
+%.c: %.y
+       $(ECHO_PREFIX) echo "   [BISON] $< -> $@"
+       $(CMD_PREFIX) bison -o $@ -d --name-prefix=ast_yy $<
+
+%.c: %.fl
+       $(ECHO_PREFIX) echo "   [FLEX] $< -> $@"
+       $(CMD_PREFIX) flex -o $@ --full $<
 
-$(eval $(call ast_make_oo_cc,%.oo,%.cc))
+%.so: %.o
+       $(ECHO_PREFIX) echo "   [LD] $^ -> $@"
+       $(CMD_PREFIX) $(CC) $(STATIC_BUILD) -o $@ $(PTHREAD_CFLAGS) $(ASTLDFLAGS) $(SOLINK) $^ $(PTHREAD_LIBS) $(LIBS)
 
-$(eval $(call ast_make_so_o,%.so,%.o))
+%.so: %.oo
+       $(ECHO_PREFIX) echo "   [LDXX] $^ -> $@"
+       $(CMD_PREFIX) $(CXX) $(STATIC_BUILD) -o $@ $(PTHREAD_CFLAGS) $(ASTLDFLAGS) $(SOLINK) $^ $(PTHREAD_LIBS) $(LIBS)
 
-$(eval $(call ast_make_so_oo,%.so,%.oo))
+%.eo: %.o
+       $(ECHO_PREFIX) echo "   [EMBED] $< -> $@"
+       $(CMD_PREFIX) $(ASTTOPDIR)/build_tools/make_linker_eo_script $* > .$@.ld
+       $(CMD_PREFIX) $(LD) -r -T .$@.ld -o $@ $<
+       $(CMD_PREFIX) rm -f .$@.ld
 
-$(eval $(call ast_make_final,%,%.o))
+%.eo: %.oo
+       $(ECHO_PREFIX) echo "   [EMBED] $< -> $@"
+       $(CMD_PREFIX) $(ASTTOPDIR)/build_tools/make_linker_eo_script $* > .$@.ld
+       $(CMD_PREFIX) $(LD) -r -T .$@.ld -o $@ $<
+       $(CMD_PREFIX) rm -f .$@.ld
 
-$(eval $(call ast_make_c_y,%.c,%.y))
+%: %.o
+       $(ECHO_PREFIX) echo "   [LD] $^ -> $@"
+       $(CMD_PREFIX) $(CXX) $(STATIC_BUILD) -o $@ $(PTHREAD_CFLAGS) $(ASTLDFLAGS) $^ $(PTHREAD_LIBS) $(LIBS)
 
-$(eval $(call ast_make_c_fl,%.c,%.fl))
+dist-clean::