* dynl-dl.c, dynl-dld.c, dynl-shl.c, dynl-vms.c: deleted
[bpt/guile.git] / libguile / Makefile.am
CommitLineData
733943b9 1## Process this file with Automake to create Makefile.in
2764bd99 2##
553bb641 3## Copyright (C) 1998, 1999 Free Software Foundation, Inc.
2764bd99
JB
4##
5## This file is part of GUILE.
6##
7## GUILE is free software; you can redistribute it and/or modify
8## it under the terms of the GNU General Public License as
9## published by the Free Software Foundation; either version 2, or
10## (at your option) any later version.
11##
12## GUILE is distributed in the hope that it will be useful, but
13## WITHOUT ANY WARRANTY; without even the implied warranty of
14## MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15## GNU General Public License for more details.
16##
17## You should have received a copy of the GNU General Public
18## License along with GUILE; see the file COPYING. If not, write
19## to the Free Software Foundation, Inc., 59 Temple Place, Suite
20## 330, Boston, MA 02111-1307 USA
733943b9
TT
21
22AUTOMAKE_OPTIONS = foreign
23
24## Check for headers in $(srcdir)/.., so that #include
25## <libguile/MUMBLE.h> will find MUMBLE.h in this dir when we're
26## building.
6165ede3 27INCLUDES = -I.. -I$(srcdir)/.. ${THREAD_CPPFLAGS} $(INCLTDL)
733943b9 28
4079f87e 29ETAGS_ARGS = --regex='/SCM_\(GLOBAL_\)?\(G?PROC\|G?PROC1\|SYMBOL\|VCELL\|CONST_LONG\).*\"\([^\"]\)*\"/\3/' \
abc049a9 30 --regex='/[ \t]*SCM_[G]?DEFINE1?[ \t]*(\([^,]*\),[^,]*/\1/'
fef07353 31
e13d8dc0 32lib_LTLIBRARIES = libguile.la
549436de
JB
33bin_PROGRAMS = guile
34
35guile_SOURCES = guile.c
a0e6f509 36guile_LDADD = libguile.la ${THREAD_LIBS_LOCAL}
6165ede3 37guile_LDFLAGS = @DLPREOPEN@
ee2a8b9b
JB
38
39libguile_la_SOURCES = \
f6e164d4
JB
40 alist.c arbiters.c async.c backtrace.c boolean.c chars.c \
41 continuations.c debug.c dynl.c dynwind.c eq.c error.c eval.c \
52cfc69b 42 evalext.c feature.c fluids.c fports.c gc.c gdbint.c \
f15913d0 43 gh_data.c gh_eval.c gh_funcs.c gh_init.c gh_io.c gh_list.c \
f6e164d4 44 gh_predicates.c gsubr.c guardians.c hash.c hashtab.c init.c \
4725c298 45 ioext.c keywords.c lang.c list.c load.c macros.c mallocs.c \
52cfc69b 46 modules.c numbers.c objects.c objprop.c options.c pairs.c \
afe5177e 47 ports.c print.c procprop.c procs.c random.c read.c \
52cfc69b 48 root.c scmsigs.c script.c simpos.c smob.c sort.c \
f6e164d4 49 srcprop.c stackchk.c stacks.c stime.c strings.c strop.c strorder.c \
afe5177e 50 strports.c struct.c symbols.c tag.c throw.c variable.c \
f6e164d4 51 vectors.c version.c vports.c weaks.c
549436de 52
a3365d47 53BUILT_SOURCES = \
f6e164d4
JB
54 cpp_err_symbols.c cpp_sig_symbols.c libpath.h alist.x arbiters.x \
55 async.x backtrace.x boolean.x chars.x continuations.x debug.x \
56 dynl.x dynwind.x eq.x error.x eval.x evalext.x feature.x filesys.x \
5d175eaf 57 fluids.x fports.x gc.x gsubr.x \
f6e164d4 58 guardians.x hash.x hashtab.x init.x ioext.x iselect.x keywords.x \
094ce856 59 lang.x list.x load.x macros.x mallocs.x modules.x net_db.x \
f6e164d4
JB
60 numbers.x objects.x objprop.x options.x pairs.x ports.x posix.x \
61 print.x procprop.x procs.x random.x ramap.x read.x regex-posix.x \
62 root.x scmsigs.x script.x simpos.x smob.x socket.x sort.x \
63 srcprop.x stackchk.x stacks.x stime.x strings.x strop.x strorder.x \
64 strports.x struct.x symbols.x tag.x threads.x throw.x unif.x \
65 variable.x vectors.x version.x vports.x weaks.x
a3365d47 66
60a059e6
JB
67EXTRA_libguile_la_SOURCES = _scm.h \
68 alloca.c inet_aton.c memmove.c putenv.c strerror.c \
52cfc69b 69 threads.c regex-posix.c iselect.c \
afe5177e
GH
70 filesys.c posix.c net_db.c socket.c \
71 ramap.c unif.c
7bfd3b9e
JB
72
73## This is kind of nasty... there are ".c" files that we don't want to
74## compile, since they are #included in threads.c. So instead we list
75## them here. Perhaps we can deal with them normally once the merge
76## seems to be working.
77noinst_HEADERS = coop-threads.c coop-threads.h coop.c
78
78bda5f3 79libguile_la_DEPENDENCIES = @LIBLOBJS@
6165ede3 80libguile_la_LIBADD = @LIBLOBJS@ $(LIBLTDL)
b3ad3103 81libguile_la_LDFLAGS = -version-info 7:0 -export-dynamic
733943b9
TT
82
83include_HEADERS = libguile.h
84
ee2a8b9b
JB
85# These are headers visible as <guile/mumble.h>
86pkginclude_HEADERS = gh.h
87
733943b9 88# These are headers visible as <libguile/mumble.h>.
5380de6b 89modincludedir = $(includedir)/libguile
99dc0f92 90modinclude_HEADERS = \
f6e164d4
JB
91 __scm.h alist.h arbiters.h async.h backtrace.h boolean.h chars.h \
92 continuations.h debug.h dynl.h dynwind.h eq.h error.h eval.h \
93 evalext.h feature.h filesys.h fports.h gc.h gdb_interface.h \
94 gdbint.h genio.h gsubr.h guardians.h hash.h hashtab.h init.h \
094ce856 95 ioext.h keywords.h kw.h lang.h list.h load.h macros.h mallocs.h \
f6e164d4
JB
96 modules.h net_db.h numbers.h objects.h objprop.h options.h pairs.h \
97 ports.h posix.h regex-posix.h print.h procprop.h procs.h random.h \
1bbd0b84 98 ramap.h read.h root.h scmsigs.h scm_validate.h script.h simpos.h smob.h socket.h \
f6e164d4
JB
99 sort.h srcprop.h stackchk.h stacks.h stime.h strings.h strop.h \
100 strorder.h strports.h struct.h symbols.h tag.h tags.h throw.h \
101 unif.h variable.h vectors.h version.h vports.h weaks.h snarf.h \
102 threads.h coop-defs.h fluids.h iselect.h
4725c298 103
adb75a41
TT
104## This file is generated at configure time. That is why it is DATA
105## and not a header -- headers are included in the distribution.
733943b9
TT
106modinclude_DATA = scmconfig.h
107
e8e9b690 108bin_SCRIPTS = guile-snarf guile-doc-snarf guile-snarf.awk
adb75a41 109
a0e6f509 110check_ldadd = libguile.la ${THREAD_LIBS_LOCAL}
ee2a8b9b
JB
111check_PROGRAMS = gh_test_c gh_test_repl
112gh_test_c_SOURCES = gh_test_c.c
113gh_test_c_LDADD = ${check_ldadd}
114gh_test_repl_SOURCES = gh_test_repl.c
115gh_test_repl_LDADD = ${check_ldadd}
116
52f980e4 117check-local:
429ae864
JB
118 echo '(+ 1 2 3)' | GUILE_LOAD_PATH=${top_srcdir}:.. ./gh_test_c; echo
119 echo '(+ 1 2 3)' | GUILE_LOAD_PATH=${top_srcdir}:.. ./gh_test_repl; echo
52f980e4 120
6165ede3
MV
121EXTRA_DIST = ChangeLog-gh ChangeLog-scm ChangeLog-threads cpp_signal.c \
122 cpp_errno.c cpp_err_symbols.in cpp_sig_symbols.in cpp_cnvt.awk \
123 coop-threads.h.cygnus coop-threads.c.cygnus mit-pthreads.h \
124 mit-pthreads.c fsu-pthreads.h
733943b9 125
fef07353 126## FIXME: Consider using timestamp file, to avoid unnecessary rebuilds.
90ff3ec5 127libpath.h: $(srcdir)/Makefile.in $(top_builddir)/config.status
e151bee6
JB
128 @echo "Generating libpath.h..."
129 @rm -f libpath.tmp
130 @echo '/* generated by Makefile */' > libpath.tmp
131 @echo '#define SCM_PKGDATA_DIR "$(pkgdatadir)"' >> libpath.tmp
132 @echo '#define SCM_LIBRARY_DIR "$(pkgdatadir)/$(VERSION)"'>>libpath.tmp
133 @echo '#define SCM_SITE_DIR "$(pkgdatadir)/site"' >> libpath.tmp
134 @echo '#define SCM_BUILD_INFO { \' >> libpath.tmp
135 @echo ' { "srcdir", "'"`cd @srcdir@; pwd`"'" }, \' >> libpath.tmp
136 @echo ' { "top_srcdir", "'"`cd @top_srcdir@; pwd`"'" }, \' \
137 >> libpath.tmp
138 @echo ' { "prefix", "@prefix@" }, \' >> libpath.tmp
139 @echo ' { "exec_prefix", "@exec_prefix@" }, \' >> libpath.tmp
140 @echo ' { "bindir", "@bindir@" }, \' >> libpath.tmp
141 @echo ' { "sbindir", "@sbindir@" }, \' >> libpath.tmp
142 @echo ' { "libexecdir", "@libexecdir@" }, \' >> libpath.tmp
143 @echo ' { "datadir", "@datadir@" }, \' >> libpath.tmp
144 @echo ' { "sysconfdir", "@sysconfdir@" }, \' >> libpath.tmp
145 @echo ' { "sharedstatedir", "@sharedstatedir@" }, \' >> libpath.tmp
146 @echo ' { "localstatedir", "@localstatedir@" }, \' >> libpath.tmp
147 @echo ' { "libdir", "@libdir@" }, \' >> libpath.tmp
148 @echo ' { "infodir", "@infodir@" }, \' >> libpath.tmp
149 @echo ' { "mandir", "@mandir@" }, \' >> libpath.tmp
150 @echo ' { "includedir", "@includedir@" }, \' >> libpath.tmp
151 @echo ' { "pkgdatadir", "$(datadir)/@PACKAGE@" }, \' >> libpath.tmp
152 @echo ' { "pkglibdir", "$(libdir)/@PACKAGE@" }, \' >> libpath.tmp
153 @echo ' { "pkgincludedir", "$(includedir)/@PACKAGE@" }, \' \
154 >> libpath.tmp
90ff3ec5 155 @echo ' { "LIBS", "@GUILE_LIBS@" }, \' >> libpath.tmp
e151bee6
JB
156 @echo '}' >> libpath.tmp
157 @mv libpath.tmp libpath.h
733943b9 158
3dc81fba
GB
159
160# ./guile-snarf $(DEFS) $(INCLUDES) $(CPPFLAGS) $(CFLAGS) $< > $@
161
162SUFFIXES = .x .doc
733943b9 163.c.x:
e8e9b690 164 ./guile-doc-snarf $< $(DEFS) $(INCLUDES) $(CPPFLAGS) $(CFLAGS) $< > $@ \
95042d95 165 || { rm $@; false; }
3dc81fba
GB
166.c.doc:
167 ./guile-doc-snarf $< $(DEFS) $(INCLUDES) $(CPPFLAGS) $(CFLAGS) $< \
168 || { rm $@; false; }
733943b9 169
4079f87e
GB
170## GJB:FIXME:: this is ugly; generate the *.doc files from the *.x file list, above
171guile-procedures.txt: *.doc
172 cat *.doc > $@
173
174pkgdata_DATA = guile-procedures.txt
175
733943b9
TT
176## Add -MG to make the .x magic work with auto-dep code.
177MKDEP = gcc -M -MG $(DEFS) $(INCLUDES) $(CPPFLAGS) $(CFLAGS)
ee78fbb0 178
a0e90145
JB
179cpp_err_symbols.c: cpp_err_symbols.in
180 $(AWK) -f $(srcdir)/cpp_cnvt.awk < $(srcdir)/cpp_err_symbols.in > \
593d151f
JB
181 cpp_err_symbols.tmp
182 mv cpp_err_symbols.tmp cpp_err_symbols.c
ee78fbb0 183
a0e90145
JB
184cpp_sig_symbols.c: cpp_sig_symbols.in
185 $(AWK) -f $(srcdir)/cpp_cnvt.awk < $(srcdir)/cpp_sig_symbols.in > \
593d151f
JB
186 cpp_sig_symbols.tmp
187 mv cpp_sig_symbols.tmp cpp_sig_symbols.c
67ec3667 188
a0e90145 189## Create a new version of the cpp_sig_symbols.in file, including all SIGXXX
67ec3667
GH
190## macros defined on this platform.
191check_signals:
192 gcc -undef -dM -E $(srcdir)/cpp_signal.c | egrep ' SIG[A-Z]+' \
193 | cut -f2 -d' ' | sort > cpp_sig_symbols_here
a0e90145
JB
194 diff -u $(srcdir)/cpp_sig_symbols.in cpp_sig_symbols_here \
195 | egrep '^\+S' \
67ec3667
GH
196 | cut -c2- > cpp_sig_symbols_diff
197 if test -s cpp_sig_symbols_diff ; then \
a0e90145 198 cat $(srcdir)/cpp_sig_symbols.in cpp_sig_symbols_diff \
67ec3667
GH
199 | sort > cpp_sig_symbols_new ;\
200 echo "cpp_sig_symbols_new has the following additions:" ;\
201 cat cpp_sig_symbols_diff ;\
202 else echo "No new symbols found."; \
203 fi
204
a0e90145 205## Likewise for cpp_err_symbols.in.
67ec3667
GH
206check_errnos:
207 gcc -undef -dM -E $(srcdir)/cpp_errno.c | egrep ' E.+' \
208 | cut -f2 -d' ' | sort > cpp_err_symbols_here
a0e90145
JB
209 diff -u $(srcdir)/cpp_err_symbols.in cpp_err_symbols_here \
210 | egrep '^\+E' \
67ec3667
GH
211 | cut -c2- > cpp_err_symbols_diff
212 if test -s cpp_err_symbols_diff ; then \
a0e90145 213 cat $(srcdir)/cpp_err_symbols.in cpp_err_symbols_diff \
67ec3667
GH
214 | sort > cpp_err_symbols_new ;\
215 echo "cpp_err_symbols_new has the following additions:" ;\
216 cat cpp_err_symbols_diff ;\
217 else echo "No new symbols found."; \
218 fi
219
ad6b30a0
TP
220MOSTLYCLEANFILES = \
221 cpp_err_symbols_here cpp_err_symbols_diff cpp_err_symbols_new \
67ec3667 222 cpp_sig_symbols_here cpp_sig_symbols_diff cpp_sig_symbols_new
ad6b30a0 223
553bb641 224CLEANFILES = libpath.h
ad6b30a0
TP
225
226DISTCLEANFILES = *.x
227