X-Git-Url: https://git.dlugolecki.net.pl/?a=blobdiff_plain;f=Makefile;h=cb9ce3dbb02a1de94104a21d73f8b0a273fc9cb7;hb=a66117df27b1fe84a06e4637156f7c9f2aa7483f;hp=737ba42c068430686d1eb522196773136b0d8875;hpb=be41e74e82065afc92849a2ce5a1c51f69ded908;p=gedcom-parse.git diff --git a/Makefile b/Makefile index 737ba42..cb9ce3d 100644 --- a/Makefile +++ b/Makefile @@ -1,14 +1,96 @@ # $Id$ # $Name$ -gedcom_parse: standalone.o lex.gedcom_.o gedcom.tab.o - cc standalone.o lex.gedcom_.o gedcom.tab.o -o gedcom_parse +LIBTOOL=libtool +YACC=bison +LEX=flex -lex.gedcom_.c: gedcom.lex gedcom.tab.h gedcom.h - flex -8 -Pgedcom_ gedcom.lex +LIBPATH=/usr/local/lib +DMALLOC_CFLAGS= +DMALLOC_LOADLIBES= +CFLAGS=-g -W -Wall -pedantic $(DMALLOC_CFLAGS) +YFLAGS=--debug --defines +LFLAGS=-8 +LOADLIBES=$(DMALLOC_LOADLIBES) +LDFLAGS_GEDCOM=-L.libs -gedcom.tab.c gedcom.tab.h: gedcom.y gedcom.h - bison --debug --defines --name-prefix=gedcom_ gedcom.y +all: ansel_module libgedcom.so gedcom_parse +gedcom_parse: standalone.o + $(CC) $(LDFLAGS) $(LDFLAGS_GEDCOM) -lgedcom $^ $(LOADLIBES) $(LDLIBS) -o $@ + +libgedcom.so: lex.gedcom_1byte_.lo lex.gedcom_hilo_.lo lex.gedcom_lohi_.lo \ + gedcom.tab.lo message.lo multilex.lo encoding.lo interface.lo + $(LIBTOOL) $(CC) $(LDFLAGS) $^ $(LOADLIBES) $(LDLIBS) -o libgedcom.la -rpath $(LIBPATH) + rm -f libgedcom.so + ln -s .libs/libgedcom.so.0.0.0 libgedcom.so + +%.lo: %.c + $(LIBTOOL) $(CC) -c $(CPPFLAGS) $(CFLAGS) $^ + +ansel_module: + cd ansel && $(MAKE) + +lex.gedcom_1byte_.c: gedcom_1byte.lex gedcom.tab.h gedcom_internal.h multilex.h \ + gedcom_lex_common.c encoding.h + $(LEX) $(LFLAGS) -Pgedcom_1byte_ gedcom_1byte.lex + +lex.gedcom_hilo_.c: gedcom_hilo.lex gedcom.tab.h gedcom_internal.h multilex.h \ + gedcom_lex_common.c encoding.h + $(LEX) $(LFLAGS) -Pgedcom_hilo_ gedcom_hilo.lex + +lex.gedcom_lohi_.c: gedcom_lohi.lex gedcom.tab.h gedcom_internal.h multilex.h \ + gedcom_lex_common.c encoding.h + $(LEX) $(LFLAGS) -Pgedcom_lohi_ gedcom_lohi.lex + +gedcom.tab.c gedcom.tab.h: gedcom.y gedcom_internal.h + $(YACC) $(YFLAGS) --name-prefix=gedcom_ gedcom.y + +.PHONY: clean clean: - rm -f core gedcom_parse *.o lex.gedcom_.c gedcom.tab.* gedcom.output + rm -f core gedcom_parse lexer_* *.o *.lo *.la .libs/* lex.gedcom_* \ + gedcom.tab.* gedcom.output libgedcom.so + cd ansel && $(MAKE) clean + +# Lexer test programs + +lexer_1byte: lex.gedcom_1byte_.test.o message.o encoding.o + $(CC) $(LDFLAGS) $^ $(LOADLIBES) $(LDLIBS) -o $@ + +lex.gedcom_1byte_.test.o: lex.gedcom_1byte_.c + $(CC) -DLEXER_TEST -c $(CPPFLAGS) $(CFLAGS) $^ -o $@ + +test_1byte: lexer_1byte + cat t/allged.ged | ./lexer_1byte + +lexer_hilo: lex.gedcom_hilo_.test.o message.o encoding.o + $(CC) $(LDFLAGS) $^ $(LOADLIBES) $(LDLIBS) -o $@ + +lex.gedcom_hilo_.test.o: lex.gedcom_hilo_.c + $(CC) -DLEXER_TEST -c $(CPPFLAGS) $(CFLAGS) $^ -o $@ + +test_hilo: lexer_hilo + cat t/uhlcl.ged | ./lexer_hilo + +lexer_lohi: lex.gedcom_lohi_.test.o message.o encoding.o + $(CC) $(LDFLAGS) $^ $(LOADLIBES) $(LDLIBS) -o $@ + +lex.gedcom_lohi_.test.o: lex.gedcom_lohi_.c + $(CC) -DLEXER_TEST -c $(CPPFLAGS) $(CFLAGS) $^ -o $@ + +test_lohi: lexer_lohi + cat t/ulhcl.ged | ./lexer_lohi + +# Test of parser + +test: all + @export GCONV_PATH=./ansel; \ + export LD_LIBRARY_PATH=.libs; \ + for file in t/*.ged; do \ + echo "=== testing $$file"; \ + ./gedcom_parse -2 $$file; \ + done + +testmem: DMALLOC_CFLAGS=-DMALLOC +testmem: DMALLOC_LOADLIBES=-ldmalloc +testmem: clean test