Copied from old documentation. Removed all Gedcom_val details.
[gedcom-parse.git] / gedcom / Makefile.am
index 4edd802864e0f615bd881509e976db2c10df30fe..abbfe56d72ea9de8b76a91fbe74b2a5f3fa341a1 100644 (file)
@@ -2,39 +2,89 @@
 # $Id$
 # $Name$
 
-INCLUDES = -I $(srcdir)/../include -DPKGDATADIR=\"$(pkgdatadir)\"
-YFLAGS   = --debug --defines --name-prefix=gedcom_
+SUBDIRS = calendar .
+
+localedir = $(datadir)/locale
+INCLUDES = -I$(srcdir)/../intl -I$(srcdir)/../include -I$(srcdir)/calendar \
+           -I$(srcdir)/../utf8 \
+           -DPKGDATADIR=\"$(pkgdatadir)\" -DLOCALEDIR=\"$(localedir)\"
+YFLAGS   = --debug --defines
 LFLAGS   = -8
-CFLAGS   = -g -O2 -W -Wall -pedantic
+CFLAGS   = -O2 -W -Wall -pedantic -Wno-long-long @EXTRA_CFLAGS@
 
 lib_LTLIBRARIES = libgedcom.la
 libgedcom_la_SOURCES = lex.gedcom_1byte_.c \
                       lex.gedcom_hilo_.c \
                       lex.gedcom_lohi_.c \
+                      lex.gedcom_date_.c \
                       gedcom.tab.c \
+                      gedcom_date.tab.c \
                        message.c \
                        multilex.c \
                        encoding.c \
-                       interface.c
-libgedcom_la_LDFLAGS = -version-info $(LIBVERSION)
+                       interface.c \
+                      date.c \
+                      hash.c \
+                      xref.c \
+                      age.c \
+                      compat.c \
+                      buffer.c \
+                      write.c \
+                      encoding_state.c
+libgedcom_la_LDFLAGS = -export-dynamic -version-info $(LIBVERSION)
+libgedcom_la_LIBADD  = calendar/libcalendar.la @INTLLIBS@
 BUILT_SOURCES = lex.gedcom_1byte_.c \
                lex.gedcom_hilo_.c \
                lex.gedcom_lohi_.c \
+               lex.gedcom_date_.c \
                gedcom.tab.c \
-               gedcom.tab.h
+               gedcom.tab.h \
+               gedcom.tabgen.h \
+               gedcom_date.tab.c \
+               gedcom_date.tab.h \
+               gedcom_date.tabgen.h \
+               tag_names.h
 noinst_HEADERS = encoding.h \
                 gedcom_internal.h \
                 interface.h \
-                multilex.h
+                multilex.h \
+                date.h \
+                hash.h \
+                xref.h \
+                age.h \
+                compat.h \
+                buffer.h \
+                tag_data.h \
+                encoding_state.h
 EXTRA_DIST = gedcom.y \
+            gedcom_date.y \
             gedcom_1byte.lex \
             gedcom_hilo.lex \
             gedcom_lohi.lex \
-            gedcom_lex_common.c
+            gedcom_date.lex \
+            gedcom_lex_common.c \
+            lex.gedcom_1byte_.c \
+            lex.gedcom_hilo_.c \
+            lex.gedcom_lohi_.c \
+            lex.gedcom_date_.c \
+            gedcom.tab.c \
+            gedcom_date.tab.c \
+            gedcom.tab.h \
+            gedcom_date.tab.h \
+             gedcom.tabgen.h \
+            gedcom_date.tabgen.h \
+            tag_names.h \
+            process_tags
+            $(BUILT_SOURCES)
+
+include $(top_srcdir)/Makefile.inc
 
 gedcom.tab.c gedcom.tab.h:     gedcom.y
        $(YACC) $(YFLAGS) --name-prefix=gedcom_ $<
 
+gedcom_date.tab.c gedcom_date.tab.h:   gedcom_date.y
+       $(YACC) $(YFLAGS) --name-prefix=gedcom_date_ $<
+
 lex.gedcom_1byte_.c:   gedcom_1byte.lex
        $(LEX) $(LFLAGS) -Pgedcom_1byte_ $<
 
@@ -44,6 +94,34 @@ lex.gedcom_hilo_.c:  gedcom_hilo.lex
 lex.gedcom_lohi_.c:    gedcom_lohi.lex
        $(LEX) $(LFLAGS) -Pgedcom_lohi_ $<
 
-lex.gedcom_1byte_.c:   gedcom.tab.h
-lex.gedcom_hilo_.c:    gedcom.tab.h
-lex.gedcom_lohi_.c:    gedcom.tab.h
+lex.gedcom_date_.c:    gedcom_date.lex
+       $(LEX) $(LFLAGS) -Pgedcom_date_ $<
+
+tag_names.h:   $(srcdir)/gedcom.tabgen.h process_tags
+       srcdir=$(srcdir); export srcdir; \
+        perl $(srcdir)/process_tags
+
+lex.gedcom_1byte_.c:   gedcom.tabgen.h gedcom_lex_common.c
+lex.gedcom_hilo_.c:    gedcom.tabgen.h gedcom_lex_common.c
+lex.gedcom_lohi_.c:    gedcom.tabgen.h gedcom_lex_common.c
+lex.gedcom_date_.c:    gedcom_date.tabgen.h
+
+# Lexer test programs
+
+EXTRA_PROGRAMS = lexer_1byte lexer_hilo lexer_lohi
+lexer_1byte_SOURCES =
+lexer_1byte_LDADD = lex.gedcom_1byte_.test.o message.o encoding.o hash.o
+lexer_hilo_SOURCES =
+lexer_hilo_LDADD = lex.gedcom_hilo_.test.o message.o encoding.o hash.o
+lexer_lohi_SOURCES =
+lexer_lohi_LDADD = lex.gedcom_lohi_.test.o message.o encoding.o hash.o
+
+lex.gedcom_1byte_.test.o:      lex.gedcom_1byte_.c
+       $(COMPILE) -DLEXER_TEST -c $(CPPFLAGS) $(CFLAGS) $< -o $@
+lex.gedcom_hilo_.test.o:       lex.gedcom_hilo_.c
+       $(COMPILE) -DLEXER_TEST -c $(CPPFLAGS) $(CFLAGS) $< -o $@
+lex.gedcom_lohi_.test.o:       lex.gedcom_lohi_.c
+       $(COMPILE) -DLEXER_TEST -c $(CPPFLAGS) $(CFLAGS) $< -o $@
+
+clean-local:
+       rm -f $(EXTRA_PROGRAMS)