* Makefile.am: Distribute num2float.i.c.
[bpt/guile.git] / libguile / Makefile.am
index 5a8cc58..9ead1f8 100644 (file)
@@ -19,7 +19,7 @@
 ##   to the Free Software Foundation, Inc., 59 Temple Place, Suite
 ##   330, Boston, MA 02111-1307 USA
 
-AUTOMAKE_OPTIONS = foreign
+AUTOMAKE_OPTIONS = gnu
 
 ## Prevent automake from adding extra -I options
 DEFS = @DEFS@
@@ -32,12 +32,14 @@ ETAGS_ARGS = --regex='/SCM_\(GLOBAL_\)?\(G?PROC\|G?PROC1\|SYMBOL\|VCELL\|CONST_L
    --regex='/[ \t]*SCM_[G]?DEFINE1?[ \t]*(\([^,]*\),[^,]*/\1/'
 
 lib_LTLIBRARIES = libguile.la
-bin_PROGRAMS = guile
+bin_PROGRAMS = guile guile_filter_doc_snarfage
 
 guile_SOURCES = guile.c
 guile_LDADD = libguile.la ${THREAD_LIBS_LOCAL}
 guile_LDFLAGS = @DLPREOPEN@
 
+guile_filter_doc_snarfage_SOURCES = c-tokenize.c
+
 libguile_la_SOURCES = alist.c arbiters.c async.c backtrace.c boolean.c     \
     chars.c continuations.c debug.c deprecation.c dynl.c dynwind.c         \
     environments.c eq.c error.c eval.c evalext.c extensions.c              \
@@ -49,8 +51,8 @@ libguile_la_SOURCES = alist.c arbiters.c async.c backtrace.c boolean.c            \
     options.c pairs.c ports.c print.c procprop.c procs.c properties.c      \
     random.c rdelim.c read.c root.c rw.c scmsigs.c script.c simpos.c smob.c \
     sort.c srcprop.c stackchk.c stacks.c stime.c strings.c strop.c         \
-    strorder.c strports.c struct.c symbols.c tag.c throw.c values.c        \
-    variable.c vectors.c version.c vports.c weaks.c symbols-deprecated.c
+    strorder.c strports.c struct.c symbols.c throw.c values.c              \
+    variable.c vectors.c version.c vports.c weaks.c
 
 DOT_X_FILES = alist.x arbiters.x async.x backtrace.x boolean.x chars.x   \
     continuations.x debug.x deprecation.x dynl.x dynwind.x               \
@@ -63,8 +65,8 @@ DOT_X_FILES = alist.x arbiters.x async.x backtrace.x boolean.x chars.x          \
     procprop.x procs.x properties.x random.x rdelim.x read.x root.x rw.x  \
     scmsigs.x script.x simpos.x smob.x sort.x srcprop.x                          \
     stackchk.x stacks.x stime.x strings.x strop.x strorder.x strports.x          \
-    struct.x symbols.x tag.x throw.x values.x variable.x vectors.x       \
-    version.x vports.x weaks.x symbols-deprecated.x
+    struct.x symbols.x throw.x values.x variable.x vectors.x             \
+    version.x vports.x weaks.x
 
 EXTRA_DOT_X_FILES = @EXTRA_DOT_X_FILES@
 
@@ -80,14 +82,13 @@ DOT_DOC_FILES = alist.doc arbiters.doc async.doc backtrace.doc                  \
     procs.doc properties.doc random.doc rdelim.doc read.doc root.doc rw.doc \
     scmsigs.doc script.doc simpos.doc smob.doc sort.doc                            \
     srcprop.doc stackchk.doc stacks.doc stime.doc strings.doc strop.doc            \
-    strorder.doc strports.doc struct.doc symbols.doc tag.doc throw.doc     \
-    values.doc variable.doc vectors.doc version.doc vports.doc weaks.doc    \
-    symbols-deprecated.doc
+    strorder.doc strports.doc struct.doc symbols.doc throw.doc             \
+    values.doc variable.doc vectors.doc version.doc vports.doc weaks.doc
 
 EXTRA_DOT_DOC_FILES = @EXTRA_DOT_DOC_FILES@
 
 BUILT_SOURCES = cpp_err_symbols.c cpp_sig_symbols.c libpath.h scmconfig.h \
-    $(DOT_X_FILES) $(EXTRA_DOT_X_FILES) $(DOT_DOC_FILES)
+    $(DOT_X_FILES) $(EXTRA_DOT_X_FILES)
 
 EXTRA_libguile_la_SOURCES = _scm.h                     \
     alloca.c inet_aton.c memmove.c putenv.c strerror.c \
@@ -100,15 +101,22 @@ EXTRA_libguile_la_SOURCES = _scm.h                        \
 OMIT_DEPENDENCIES = libguile.h ltdl.h \
     axp.h hppa.h i386.h ksr.h m88k.h mips.h sparc.h vax.h
 
+## delete guile-snarf.awk from the installation bindir, in case it's
+## lingering there due to an earlier guile version not having been
+## wiped out.
+install-exec-hook:
+       rm -f $(bindir)/guile-snarf.awk
+
 ## This is kind of nasty... there are ".c" files that we don't want to
 ## compile, since they are #included.  So instead we list them here.
 ## Perhaps we can deal with them normally once the merge seems to be
 ## working.
-noinst_HEADERS = coop-threads.c coop-threads.h coop.c num2integral.i.c
+noinst_HEADERS = coop-threads.c coop-threads.h coop.c \
+                num2integral.i.c num2float.i.c
 
 libguile_la_DEPENDENCIES = @LIBLOBJS@
 libguile_la_LIBADD = @LIBLOBJS@ $(LIBLTDL)
-libguile_la_LDFLAGS = -version-info @LIBGUILE_MAJOR_VERSION@:@LIBGUILE_MINOR_VERSION@:@LIBGUILE_REVISION_VERSION@ -export-dynamic
+libguile_la_LDFLAGS = -version-info @LIBGUILE_INTERFACE_CURRENT@:@LIBGUILE_INTERFACE_REVISION@:@LIBGUILE_INTERFACE_AGE@ -export-dynamic
 
 # These are headers visible as <guile/mumble.h> 
 pkginclude_HEADERS = gh.h
@@ -126,17 +134,22 @@ modinclude_HEADERS = __scm.h alist.h arbiters.h async.h backtrace.h boolean.h \
     regex-posix.h print.h procprop.h procs.h properties.h random.h ramap.h    \
     rdelim.h read.h root.h rw.h scmsigs.h validate.h script.h simpos.h smob.h \
     snarf.h socket.h sort.h srcprop.h stackchk.h stacks.h stime.h strings.h   \
-    strop.h strorder.h strports.h struct.h symbols.h tag.h tags.h threads.h   \
+    strop.h strorder.h strports.h struct.h symbols.h tags.h threads.h        \
     throw.h unif.h values.h variable.h vectors.h version.h vports.h weaks.h
 
 ## This file is generated at configure time.  That is why it is DATA
 ## and not a header -- headers are included in the distribution.
 modinclude_DATA = scmconfig.h
 
-bin_SCRIPTS = guile-snarf guile-doc-snarf guile-snarf.awk guile-func-name-check
+bin_SCRIPTS = guile-snarf guile-doc-snarf guile-snarf-docs \
+    guile-snarf-docs-texi guile-func-name-check
 
-EXTRA_DIST = ChangeLog-gh ChangeLog-scm ChangeLog-threads cpp_signal.c \
-    cpp_errno.c cpp_err_symbols.in cpp_sig_symbols.in cpp_cnvt.awk
+EXTRA_DIST = ChangeLog-gh ChangeLog-scm ChangeLog-threads              \
+    ChangeLog-1996-1999 ChangeLog-2000 cpp_signal.c                    \
+    cpp_errno.c cpp_err_symbols.in cpp_sig_symbols.in cpp_cnvt.awk     \
+    c-tokenize.lex
+#    $(DOT_DOC_FILES) $(EXTRA_DOT_DOC_FILES) \
+#    guile-procedures.txt guile.texi
 
 ## FIXME: Consider using timestamp file, to avoid unnecessary rebuilds.
 libpath.h: $(srcdir)/Makefile.in  $(top_builddir)/config.status
@@ -168,37 +181,40 @@ libpath.h: $(srcdir)/Makefile.in  $(top_builddir)/config.status
        @echo ' { "pkgincludedir", "$(includedir)/@PACKAGE@" }, \' \
                >> libpath.tmp
        @echo ' { "guileversion", "@GUILE_VERSION@" }, \' >> libpath.tmp
-       @echo ' { "libguileversion", "@LIBGUILE_VERSION@" }, \' >> libpath.tmp
+       @echo ' { "libguileinterface", "@LIBGUILE_INTERFACE@" }, \' >> libpath.tmp
        @echo ' { "LIBS",          "@GUILE_LIBS@" }, \' >> libpath.tmp
        @echo '}' >> libpath.tmp
        @mv libpath.tmp libpath.h
 
 
-#      ./guile-snarf $(DEFS) $(INCLUDES) $(CPPFLAGS) $(CFLAGS) $< > $@ 
-
 SUFFIXES = .x .doc
 .c.x:
-       ./guile-doc-snarf $< $(DEFS) $(INCLUDES) $(CPPFLAGS) $(CFLAGS) $< > $@ \
+       ./guile-snarf $(DEFS) $(INCLUDES) $(CPPFLAGS) $(CFLAGS) $< > $@ \
        || { rm $@; false; }
-.x.doc:
-       ./guile-doc-snarf $(srcdir)/$*.c $(DEFS) $(INCLUDES) $(CPPFLAGS) $(CFLAGS) $(srcdir)/$*.c > /dev/null \
-        || { rm $@; false; }
+.c.doc:
+       -(test -n "${AWK+set}" || AWK="@AWK@"; ${AWK} -f ./guile-func-name-check $<)
+       (./guile-snarf-docs $(DEFS) $(INCLUDES) $(CPPFLAGS) $(CFLAGS) $< | \
+       ./guile_filter_doc_snarfage --filter-snarfage) > $@ || { rm $@; false; }
+
+$(DOT_X_FILES) $(EXTRA_DOT_DOC_FILES): snarf.h guile-snarf.in
 
-*.x: snarf.h guile-doc-snarf.in
-*.doc: guile-snarf.awk.in
+$(DOT_DOC_FILES) $(EXTRA_DOT_DOC_FILES): snarf.h guile-snarf-docs.in guile_filter_doc_snarfage
 
 error.x: cpp_err_symbols.c
 posix.x: cpp_sig_symbols.c
 load.x: libpath.h
 
-guile.texi: $(DOT_DOC_FILES) $(EXTRA_DOT_DOC_FILES)
-       echo "@paragraphindent 0" > $@
-       cat *.doc >> $@
+guile.texi: $(DOT_DOC_FILES) $(EXTRA_DOT_DOC_FILES) guile-snarf-docs-texi.in guile
+       cat $(DOT_DOC_FILES) $(EXTRA_DOT_DOC_FILES) | ./guile-snarf-docs-texi > $@ \
+       || { rm $@; false; }
 
 guile-procedures.txt: guile.texi
        rm -f $@
        makeinfo --force -o $@ $< || test -f $@
 
+c-tokenize.c: c-tokenize.lex
+       flex -t $< > $@ || { rm $@; false; }
+
 schemelibdir = $(pkgdatadir)/$(VERSION)
 schemelib_DATA = guile-procedures.txt
 
@@ -250,4 +266,6 @@ MOSTLYCLEANFILES = \
        cpp_err_symbols_here cpp_err_symbols_diff cpp_err_symbols_new \
        cpp_sig_symbols_here cpp_sig_symbols_diff cpp_sig_symbols_new
 
-CLEANFILES = libpath.h *.x *.doc
+CLEANFILES = libpath.h *.x *.doc guile-procedures.txt guile.texi
+
+MAINTAINERCLEANFILES = c-tokenize.c