Add support for manager hooks, so you could fire off manager events over IRC if you...
[asterisk/asterisk.git] / utils / Makefile
index d88beee..747e048 100644 (file)
 # the GNU General Public License
 #
 
-#
-# Don't use ast mm routines
-#
-UTILS:=astman smsq stereorize streamplayer
+.PHONY: clean clean-depend all depend uninstall
+
+ALL_UTILS:=astman smsq stereorize streamplayer aelparse muted
+UTILS:=$(ALL_UTILS)
 
-ifeq (${OSARCH},SunOS)
-  SOL=../strcompat.o
-  SOLLIBS=-lsocket -lnsl
+include $(ASTTOPDIR)/Makefile.rules
+
+ifeq ($(OSARCH),SunOS)
+  LIBS+=-lsocket -lnsl
+  UTILS:=$(filter-out muted,$(UTILS))
+endif
+
+ifeq ($(OSARCH),OpenBSD)
+  UTILS:=$(filter-out muted,$(UTILS))
 endif
 
 ifeq ($(POPT_LIB),)
@@ -29,7 +35,11 @@ ifeq ($(NEWT_LIB),)
   UTILS:=$(filter-out astman,$(UTILS))
 endif
 
-all: depend $(UTILS)
+ifneq ($(filter pbx_ael,$(MENUSELECT_PBX)),)
+  UTILS:=$(filter-out aelparse,$(UTILS))
+endif
+
+all: $(UTILS)
 
 install:
        for x in $(UTILS); do \
@@ -39,57 +49,78 @@ install:
        done 
 
 uninstall:
-       for x in $(TARGET); do rm -f $$x $(DESTDIR)$(ASTSBINDIR)/$$x; done
+       for x in $(ALL_UTILS); do rm -f $$x $(DESTDIR)$(ASTSBINDIR)/$$x; done
 
 clean-depend:
        rm -f .depend
 
 clean: clean-depend
-       rm -f *.o $(TARGET) check_expr
-       rm -f ast_expr2.o ast_expr2f.o
+       rm -f *.o $(ALL_UTILS) check_expr
+       rm -f md5.c strcompat.c ast_expr2.c ast_expr2f.c pbx_ael.c
+       rm -f aelparse.c aelbison.c
 
-astman.o: astman.c
-       $(CC) $(CFLAGS) -include ../include/autoconfig.h -c -o $@ $<
+md5.c: ../main/md5.c
+       @cp $< $@
 
-astman: astman.o ../md5.o
-       $(CC) -D_GNU_SOURCE -o $@ $< ../md5.o -lnewt
+astman: astman.o md5.o
+astman: LIBS+=$(NEWT_LIB)
 
 stereorize: stereorize.o frame.o
-       $(CC) $(CFLAGS) -o stereorize stereorize.o frame.o -lm
+stereorize: LIBS+=-lm
+
+strcompat.c: ../main/strcompat.c
+       @cp $< $@
 
-ast_expr2.o: ../ast_expr2.c
-       gcc -g -c -o $@ $<
+../main/ast_expr2.c:
+       @echo "   [BISON] ../main/ast_expr2.y -> $@"
+       @bison -o $@ -d --name-prefix=ast_yy ../main/ast_expr2.y
 
-ast_expr2f.o: ../ast_expr2f.c
-       gcc -g -c -DSTANDALONE -o $@ $<
+../main/ast_expr2f.c:
+       @echo "   [FLEX] ../main/ast_expr2.fl -> $@"
+       @flex -o $@ --full ../main/ast_expr2.fl
+
+ast_expr2.c: ../main/ast_expr2.c
+       @cp $< $@
+
+ast_expr2f.c: ../main/ast_expr2f.c
+       @cp $< $@
+
+ast_expr2f.o: ASTCFLAGS+=-DSTANDALONE_AEL -I../main
 
 check_expr: check_expr.c ast_expr2.o ast_expr2f.o
-       $(CC) $(CFLAGS) -o $@ $^
 
-aelparse : ../pbx/ael/aelflex.o ../pbx/ael/aelbison.o ../pbx/pbx_ael.o ael_main.o ../ast_expr2f.o ../ast_expr2.o
-       $(CC) $(CFLAGS) -g -o aelparse ../pbx/ael/aelflex.o ../pbx/ael/aelbison.o ael_main.o ../pbx/pbx_ael.o ../ast_expr2f.o ../ast_expr2.o
+aelbison.c: ../pbx/ael/ael.tab.c
+       @cp $< $@
+aelbison.o: aelbison.c ../pbx/ael/ael.tab.h ../include/asterisk/ael_structs.h
+aelbison.o: ASTCFLAGS+=-I../pbx
+
+pbx_ael.c: ../pbx/pbx_ael.c
+       @cp $< $@
+pbx_ael.o: ASTCFLAGS+=-DSTANDALONE_AEL
 
-ael_main.o : ael_main.c ../include/asterisk/ael_structs.h
-       $(CC) $(CFLAGS) -c -g -o ael_main.o ael_main.c
+ael_main.o: ael_main.c ../include/asterisk/ael_structs.h
 
-ael_main1.o : ael_main.c ../include/asterisk/ael_structs.h
-       $(CC) $(CFLAGS) -c -g  -o ael_main1.o ael_main.c
+aelparse.c: ../pbx/ael/ael_lex.c
+       @cp $< $@
+aelparse.o: aelparse.c ../include/asterisk/ael_structs.h ../pbx/ael/ael.tab.h
+aelparse.o: ASTCFLAGS+=-I../pbx -DSTANDALONE_AEL
 
-testexpr2s: ../ast_expr2f.c ../ast_expr2.c ../ast_expr2.h
-       gcc -g -c -I../include -DSTANDALONE ../ast_expr2f.c -o ast_expr2f.o
-       gcc -g -c -I../include -DSTANDALONE ../ast_expr2.c -o ast_expr2.o
-       gcc -g -o testexpr2s ast_expr2f.o ast_expr2.o
+aelparse: aelparse.o aelbison.o pbx_ael.o ael_main.o ast_expr2f.o ast_expr2.o strcompat.o
+
+testexpr2s: ../main/ast_expr2f.c ../main/ast_expr2.c ../main/ast_expr2.h
+       $(CC) -g -c -I../include -DSTANDALONE_AEL ../main/ast_expr2f.c -o ast_expr2f.o
+       $(CC) -g -c -I../include -DSTANDALONE_AEL ../main/ast_expr2.c -o ast_expr2.o
+       $(CC) -g -o testexpr2s ast_expr2f.o ast_expr2.o
        rm ast_expr2.o ast_expr2f.o 
        ./testexpr2s expr2.testinput
 
-smsq.o: smsq.c
-       $(CC) $(CFLAGS) -include ../include/autoconfig.h -c -o $@ $<
-
-smsq: smsq.o
-       $(CC) $(CFLAGS) -o smsq ${SOL} smsq.o -lpopt
+smsq: smsq.o strcompat.o
+smsq: LIBS+=$(POPT_LIB)
 
 streamplayer: streamplayer.o
-       $(CC) $(CFLAGS) -o streamplayer ${SOL} streamplayer.o ${SOLLIBS}
+
+muted: muted.o
+muted: LIBS+=$(AUDIO_LIBS)
 
 ifneq ($(wildcard .depend),)
   include .depend
@@ -98,5 +129,4 @@ endif
 depend: .depend
 
 .depend:
-       ../build_tools/mkdep $(CFLAGS) `ls *.c`
-
+       ../build_tools/mkdep $(ASTCFLAGS) `ls *.c`