X-Git-Url: http://git.hcoop.net/bpt/guile.git/blobdiff_plain/733943b9d29cd196d0ec2bc85178ee83a5a36c9a..f85a9bcf5fcd8ebf591e0accc0a25e24140d5fad:/libguile/Makefile.am diff --git a/libguile/Makefile.am b/libguile/Makefile.am dissimilarity index 81% index 444970cec..e9f22e13d 100644 --- a/libguile/Makefile.am +++ b/libguile/Makefile.am @@ -1,56 +1,230 @@ -## Process this file with Automake to create Makefile.in - -AUTOMAKE_OPTIONS = foreign - -## Check for headers in $(srcdir)/.., so that #include -## will find MUMBLE.h in this dir when we're -## building. -INCLUDES = -I.. -I$(srcdir)/.. - -lib_LIBRARIES = libguile.a -libguile_a_SOURCES = alist.c append.c appinit.c arbiters.c async.c \ -backtrace.c boolean.c chars.c continuations.c debug.c dynwind.c eq.c \ -error.c eval.c extchrs.c fdsocket.c feature.c filesys.c fports.c gc.c \ -gdbint.c genio.c gsubr.c hash.c hashtab.c inet_aton.c init.c ioext.c \ -kw.c list.c load.c mallocs.c markers.c mbstrings.c numbers.c objprop.c \ -options.c pairs.c ports.c posix.c print.c procprop.c procs.c ramap.c \ -read.c root.c scmsigs.c sequences.c simpos.c smob.c socket.c srcprop.c \ -stackchk.c stacks.c stime.c strerror.c strings.c strop.c strorder.c \ -strports.c struct.c symbols.c tag.c throw.c unif.c variable.c \ -vectors.c version.c vports.c weaks.c _scm.h - -include_HEADERS = libguile.h - -# These are headers visible as . -modincludedir = $(includedir)/@module@ -modinclude_HEADERS = __scm.h alist.h append.h arbiters.h async.h \ -backtrace.h boolean.h chars.h continuations.h debug.h dynwind.h eq.h \ -error.h eval.h extchrs.h fdsocket.h feature.h filesys.h fports.h gc.h \ -gdb_interface.h gdbint.h genio.h gsubr.h hash.h hashtab.h init.h ioext.h \ -kw.h list.h load.h mallocs.h markers.h mbstrings.h numbers.h objprop.h \ -options.h pairs.h ports.h posix.h print.h procprop.h procs.h ramap.h read.h \ -root.h scmhob.h scmsigs.h sequences.h simpos.h smob.h socket.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 throw.h unif.h variable.h vectors.h version.h \ -vports.h weaks.h snarf.h - -## This file is generated at configure time. -modinclude_DATA = scmconfig.h - -EXTRA_DIST = gscm.c gscm.h ChangeLog-scm PLUGIN/REQ PLUGIN/guile.config \ -PLUGIN/guile.libs - -## FIXME: shouldn't directly generate file; instead generate temp file -## and "mv". Consider using timestamp file as well, to avoid -## unnecessary rebuilds. -libpath.h: Makefile - echo '/* generated by Makefile */' > libpath.h - echo '#define LIBRARY_PATH "$(pkgdatadir)/$(VERSION)"' >> libpath.h - -SUFFIXES = .x -.c.x: - $(CPP) $(DEFS) $(INCLUDES) $(CPPFLAGS) $(CFLAGS) \ - -DSCM_MAGIC_SNARFER $< | grep "^%%%" | sed -e "s/^%%%//" > $@ - -## Add -MG to make the .x magic work with auto-dep code. -MKDEP = gcc -M -MG $(DEFS) $(INCLUDES) $(CPPFLAGS) $(CFLAGS) +## Process this file with Automake to create Makefile.in +## +## Copyright (C) 1998, 1999, 2000 Free Software Foundation, Inc. +## +## This file is part of GUILE. +## +## GUILE is free software; you can redistribute it and/or modify +## it under the terms of the GNU General Public License as +## published by the Free Software Foundation; either version 2, or +## (at your option) any later version. +## +## GUILE is distributed in the hope that it will be useful, but +## WITHOUT ANY WARRANTY; without even the implied warranty of +## MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +## GNU General Public License for more details. +## +## You should have received a copy of the GNU General Public +## License along with GUILE; see the file COPYING. If not, write +## to the Free Software Foundation, Inc., 59 Temple Place, Suite +## 330, Boston, MA 02111-1307 USA + +AUTOMAKE_OPTIONS = foreign + +## Check for headers in $(srcdir)/.., so that #include +## will find MUMBLE.h in this dir when we're +## building. +INCLUDES = -I.. -I$(srcdir)/.. ${THREAD_CPPFLAGS} $(INCLTDL) + +ETAGS_ARGS = --regex='/SCM_\(GLOBAL_\)?\(G?PROC\|G?PROC1\|SYMBOL\|VCELL\|CONST_LONG\).*\"\([^\"]\)*\"/\3/' \ + --regex='/[ \t]*SCM_[G]?DEFINE1?[ \t]*(\([^,]*\),[^,]*/\1/' + +lib_LTLIBRARIES = libguile.la +bin_PROGRAMS = guile + +guile_SOURCES = guile.c +guile_LDADD = libguile.la ${THREAD_LIBS_LOCAL} +guile_LDFLAGS = @DLPREOPEN@ + +libguile_la_SOURCES = \ + alist.c arbiters.c async.c backtrace.c boolean.c chars.c \ + continuations.c debug.c dynl.c dynwind.c eq.c error.c eval.c \ + evalext.c feature.c fluids.c fports.c gc.c gdbint.c \ + gh_data.c gh_eval.c gh_funcs.c gh_init.c gh_io.c gh_list.c \ + gh_predicates.c gsubr.c guardians.c hash.c hashtab.c init.c \ + ioext.c iselect.c keywords.c lang.c list.c load.c macros.c mallocs.c \ + modules.c numbers.c objects.c objprop.c options.c pairs.c \ + ports.c print.c procprop.c procs.c random.c read.c \ + root.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 variable.c \ + vectors.c version.c vports.c weaks.c + +DOT_X_FILES = \ + cpp_err_symbols.c cpp_sig_symbols.c libpath.h alist.x arbiters.x \ + async.x backtrace.x boolean.x chars.x continuations.x debug.x \ + dynl.x dynwind.x eq.x error.x eval.x evalext.x feature.x filesys.x \ + fluids.x fports.x gc.x gsubr.x \ + guardians.x hash.x hashtab.x init.x ioext.x iselect.x keywords.x \ + lang.x list.x load.x macros.x mallocs.x modules.x net_db.x \ + numbers.x objects.x objprop.x options.x pairs.x ports.x posix.x \ + print.x procprop.x procs.x random.x ramap.x read.x regex-posix.x \ + root.x scmsigs.x script.x simpos.x smob.x socket.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 threads.x throw.x unif.x \ + variable.x vectors.x version.x vports.x weaks.x + +DOT_DOC_FILES = $(DOT_X_FILES:.x=.doc) + +BUILT_SOURCES = $(DOT_X_FILES) $(DOT_DOC_FILES) + +EXTRA_libguile_la_SOURCES = _scm.h \ + alloca.c inet_aton.c memmove.c putenv.c strerror.c \ + threads.c regex-posix.c \ + filesys.c posix.c net_db.c socket.c \ + ramap.c unif.c + +## This is kind of nasty... there are ".c" files that we don't want to +## compile, since they are #included in threads.c. 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 + +libguile_la_DEPENDENCIES = @LIBLOBJS@ +libguile_la_LIBADD = @LIBLOBJS@ $(LIBLTDL) +libguile_la_LDFLAGS = -version-info 8:0 -export-dynamic + +include_HEADERS = libguile.h + +# These are headers visible as +pkginclude_HEADERS = gh.h + +# These are headers visible as . +modincludedir = $(includedir)/libguile +modinclude_HEADERS = \ + __scm.h alist.h arbiters.h async.h backtrace.h boolean.h chars.h \ + continuations.h debug.h dynl.h dynwind.h eq.h error.h eval.h \ + evalext.h feature.h filesys.h fports.h gc.h gdb_interface.h \ + gdbint.h gsubr.h guardians.h hash.h hashtab.h init.h \ + ioext.h keywords.h kw.h lang.h list.h load.h macros.h mallocs.h \ + modules.h net_db.h numbers.h objects.h objprop.h options.h pairs.h \ + ports.h posix.h regex-posix.h print.h procprop.h procs.h random.h \ + ramap.h read.h root.h scmsigs.h validate.h script.h simpos.h smob.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 throw.h \ + unif.h variable.h vectors.h version.h vports.h weaks.h snarf.h \ + threads.h coop-defs.h fluids.h iselect.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 + +check_ldadd = libguile.la ${THREAD_LIBS_LOCAL} +check_PROGRAMS = gh_test_c gh_test_repl +gh_test_c_SOURCES = gh_test_c.c +gh_test_c_LDADD = ${check_ldadd} +gh_test_repl_SOURCES = gh_test_repl.c +gh_test_repl_LDADD = ${check_ldadd} + +check-local: + echo '(+ 1 2 3)' | GUILE_LOAD_PATH=${top_srcdir}:.. ./gh_test_c; echo + echo '(+ 1 2 3)' | GUILE_LOAD_PATH=${top_srcdir}:.. ./gh_test_repl; echo + +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 \ + coop-threads.h.cygnus coop-threads.c.cygnus mit-pthreads.h \ + mit-pthreads.c fsu-pthreads.h + +## FIXME: Consider using timestamp file, to avoid unnecessary rebuilds. +libpath.h: $(srcdir)/Makefile.in $(top_builddir)/config.status + @echo "Generating libpath.h..." + @rm -f libpath.tmp + @echo '/* generated by Makefile */' > libpath.tmp + @echo '#define SCM_PKGDATA_DIR "$(pkgdatadir)"' >> libpath.tmp + @echo '#define SCM_LIBRARY_DIR "$(pkgdatadir)/$(VERSION)"'>>libpath.tmp + @echo '#define SCM_SITE_DIR "$(pkgdatadir)/site"' >> libpath.tmp + @echo '#define SCM_BUILD_INFO { \' >> libpath.tmp + @echo ' { "srcdir", "'"`cd @srcdir@; pwd`"'" }, \' >> libpath.tmp + @echo ' { "top_srcdir", "'"`cd @top_srcdir@; pwd`"'" }, \' \ + >> libpath.tmp + @echo ' { "prefix", "@prefix@" }, \' >> libpath.tmp + @echo ' { "exec_prefix", "@exec_prefix@" }, \' >> libpath.tmp + @echo ' { "bindir", "@bindir@" }, \' >> libpath.tmp + @echo ' { "sbindir", "@sbindir@" }, \' >> libpath.tmp + @echo ' { "libexecdir", "@libexecdir@" }, \' >> libpath.tmp + @echo ' { "datadir", "@datadir@" }, \' >> libpath.tmp + @echo ' { "sysconfdir", "@sysconfdir@" }, \' >> libpath.tmp + @echo ' { "sharedstatedir", "@sharedstatedir@" }, \' >> libpath.tmp + @echo ' { "localstatedir", "@localstatedir@" }, \' >> libpath.tmp + @echo ' { "libdir", "@libdir@" }, \' >> libpath.tmp + @echo ' { "infodir", "@infodir@" }, \' >> libpath.tmp + @echo ' { "mandir", "@mandir@" }, \' >> libpath.tmp + @echo ' { "includedir", "@includedir@" }, \' >> libpath.tmp + @echo ' { "pkgdatadir", "$(datadir)/@PACKAGE@" }, \' >> libpath.tmp + @echo ' { "pkglibdir", "$(libdir)/@PACKAGE@" }, \' >> libpath.tmp + @echo ' { "pkgincludedir", "$(includedir)/@PACKAGE@" }, \' \ + >> 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: + PATH=.:${PATH} ./guile-doc-snarf $< $(DEFS) $(INCLUDES) $(CPPFLAGS) $(CFLAGS) $< > $@ \ + || { rm $@; false; } +.c.doc: + PATH=.:${PATH} ./guile-doc-snarf $< $(DEFS) $(INCLUDES) $(CPPFLAGS) $(CFLAGS) $< \ + || { rm $@; false; } + +guile-procedures.txt: $(DOT_DOC_FILES) + cat *.doc > $@ + +pkgdata_DATA = guile-procedures.txt + +## Add -MG to make the .x magic work with auto-dep code. +MKDEP = gcc -M -MG $(DEFS) $(INCLUDES) $(CPPFLAGS) $(CFLAGS) + +cpp_err_symbols.c: cpp_err_symbols.in + $(AWK) -f $(srcdir)/cpp_cnvt.awk < $(srcdir)/cpp_err_symbols.in > \ + cpp_err_symbols.tmp + mv cpp_err_symbols.tmp cpp_err_symbols.c + +cpp_sig_symbols.c: cpp_sig_symbols.in + $(AWK) -f $(srcdir)/cpp_cnvt.awk < $(srcdir)/cpp_sig_symbols.in > \ + cpp_sig_symbols.tmp + mv cpp_sig_symbols.tmp cpp_sig_symbols.c + +## Create a new version of the cpp_sig_symbols.in file, including all SIGXXX +## macros defined on this platform. +check_signals: + gcc -undef -dM -E $(srcdir)/cpp_signal.c | egrep ' SIG[A-Z]+' \ + | cut -f2 -d' ' | sort > cpp_sig_symbols_here + diff -u $(srcdir)/cpp_sig_symbols.in cpp_sig_symbols_here \ + | egrep '^\+S' \ + | cut -c2- > cpp_sig_symbols_diff + if test -s cpp_sig_symbols_diff ; then \ + cat $(srcdir)/cpp_sig_symbols.in cpp_sig_symbols_diff \ + | sort > cpp_sig_symbols_new ;\ + echo "cpp_sig_symbols_new has the following additions:" ;\ + cat cpp_sig_symbols_diff ;\ + else echo "No new symbols found."; \ + fi + +## Likewise for cpp_err_symbols.in. +check_errnos: + gcc -undef -dM -E $(srcdir)/cpp_errno.c | egrep ' E.+' \ + | cut -f2 -d' ' | sort > cpp_err_symbols_here + diff -u $(srcdir)/cpp_err_symbols.in cpp_err_symbols_here \ + | egrep '^\+E' \ + | cut -c2- > cpp_err_symbols_diff + if test -s cpp_err_symbols_diff ; then \ + cat $(srcdir)/cpp_err_symbols.in cpp_err_symbols_diff \ + | sort > cpp_err_symbols_new ;\ + echo "cpp_err_symbols_new has the following additions:" ;\ + cat cpp_err_symbols_diff ;\ + else echo "No new symbols found."; \ + fi + +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 + +DISTCLEANFILES = *.x *.doc +