* boot-9.scm (try-using-libtool-name): Do not bother to look
[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.
a0e6f509 27INCLUDES = -I.. -I$(srcdir)/.. ${THREAD_CPPFLAGS}
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}
ee2a8b9b
JB
37
38libguile_la_SOURCES = \
f6e164d4
JB
39 alist.c arbiters.c async.c backtrace.c boolean.c chars.c \
40 continuations.c debug.c dynl.c dynwind.c eq.c error.c eval.c \
52cfc69b 41 evalext.c feature.c fluids.c fports.c gc.c gdbint.c \
f15913d0 42 gh_data.c gh_eval.c gh_funcs.c gh_init.c gh_io.c gh_list.c \
f6e164d4 43 gh_predicates.c gsubr.c guardians.c hash.c hashtab.c init.c \
4725c298 44 ioext.c keywords.c lang.c list.c load.c macros.c mallocs.c \
52cfc69b 45 modules.c numbers.c objects.c objprop.c options.c pairs.c \
afe5177e 46 ports.c print.c procprop.c procs.c random.c read.c \
52cfc69b 47 root.c scmsigs.c script.c simpos.c smob.c sort.c \
f6e164d4 48 srcprop.c stackchk.c stacks.c stime.c strings.c strop.c strorder.c \
afe5177e 49 strports.c struct.c symbols.c tag.c throw.c variable.c \
f6e164d4 50 vectors.c version.c vports.c weaks.c
549436de 51
a3365d47 52BUILT_SOURCES = \
f6e164d4
JB
53 cpp_err_symbols.c cpp_sig_symbols.c libpath.h alist.x arbiters.x \
54 async.x backtrace.x boolean.x chars.x continuations.x debug.x \
55 dynl.x dynwind.x eq.x error.x eval.x evalext.x feature.x filesys.x \
5d175eaf 56 fluids.x fports.x gc.x gsubr.x \
f6e164d4 57 guardians.x hash.x hashtab.x init.x ioext.x iselect.x keywords.x \
094ce856 58 lang.x list.x load.x macros.x mallocs.x modules.x net_db.x \
f6e164d4
JB
59 numbers.x objects.x objprop.x options.x pairs.x ports.x posix.x \
60 print.x procprop.x procs.x random.x ramap.x read.x regex-posix.x \
61 root.x scmsigs.x script.x simpos.x smob.x socket.x sort.x \
62 srcprop.x stackchk.x stacks.x stime.x strings.x strop.x strorder.x \
63 strports.x struct.x symbols.x tag.x threads.x throw.x unif.x \
64 variable.x vectors.x version.x vports.x weaks.x
a3365d47 65
60a059e6
JB
66EXTRA_libguile_la_SOURCES = _scm.h \
67 alloca.c inet_aton.c memmove.c putenv.c strerror.c \
52cfc69b 68 threads.c regex-posix.c iselect.c \
afe5177e
GH
69 filesys.c posix.c net_db.c socket.c \
70 ramap.c unif.c
7bfd3b9e
JB
71
72## This is kind of nasty... there are ".c" files that we don't want to
73## compile, since they are #included in threads.c. So instead we list
74## them here. Perhaps we can deal with them normally once the merge
75## seems to be working.
76noinst_HEADERS = coop-threads.c coop-threads.h coop.c
77
78bda5f3 78libguile_la_DEPENDENCIES = @LIBLOBJS@
4a5fa91c 79libguile_la_LIBADD = @LIBLOBJS@
b3ad3103 80libguile_la_LDFLAGS = -version-info 7:0 -export-dynamic
733943b9
TT
81
82include_HEADERS = libguile.h
83
ee2a8b9b
JB
84# These are headers visible as <guile/mumble.h>
85pkginclude_HEADERS = gh.h
86
733943b9 87# These are headers visible as <libguile/mumble.h>.
5380de6b 88modincludedir = $(includedir)/libguile
99dc0f92 89modinclude_HEADERS = \
f6e164d4
JB
90 __scm.h alist.h arbiters.h async.h backtrace.h boolean.h chars.h \
91 continuations.h debug.h dynl.h dynwind.h eq.h error.h eval.h \
92 evalext.h feature.h filesys.h fports.h gc.h gdb_interface.h \
93 gdbint.h genio.h gsubr.h guardians.h hash.h hashtab.h init.h \
094ce856 94 ioext.h keywords.h kw.h lang.h list.h load.h macros.h mallocs.h \
f6e164d4
JB
95 modules.h net_db.h numbers.h objects.h objprop.h options.h pairs.h \
96 ports.h posix.h regex-posix.h print.h procprop.h procs.h random.h \
1bbd0b84 97 ramap.h read.h root.h scmsigs.h scm_validate.h script.h simpos.h smob.h socket.h \
f6e164d4
JB
98 sort.h srcprop.h stackchk.h stacks.h stime.h strings.h strop.h \
99 strorder.h strports.h struct.h symbols.h tag.h tags.h throw.h \
100 unif.h variable.h vectors.h version.h vports.h weaks.h snarf.h \
101 threads.h coop-defs.h fluids.h iselect.h
4725c298 102
adb75a41
TT
103## This file is generated at configure time. That is why it is DATA
104## and not a header -- headers are included in the distribution.
733943b9
TT
105modinclude_DATA = scmconfig.h
106
e8e9b690 107bin_SCRIPTS = guile-snarf guile-doc-snarf guile-snarf.awk
adb75a41 108
a0e6f509 109check_ldadd = libguile.la ${THREAD_LIBS_LOCAL}
ee2a8b9b
JB
110check_PROGRAMS = gh_test_c gh_test_repl
111gh_test_c_SOURCES = gh_test_c.c
112gh_test_c_LDADD = ${check_ldadd}
113gh_test_repl_SOURCES = gh_test_repl.c
114gh_test_repl_LDADD = ${check_ldadd}
115
52f980e4 116check-local:
429ae864
JB
117 echo '(+ 1 2 3)' | GUILE_LOAD_PATH=${top_srcdir}:.. ./gh_test_c; echo
118 echo '(+ 1 2 3)' | GUILE_LOAD_PATH=${top_srcdir}:.. ./gh_test_repl; echo
52f980e4 119
1773993b
JB
120EXTRA_DIST = ChangeLog-gh ChangeLog-scm ChangeLog-threads dynl-dl.c \
121 dynl-dld.c dynl-shl.c dynl-vms.c DYNAMIC-LINKING cpp_signal.c cpp_errno.c \
122 cpp_err_symbols.in cpp_sig_symbols.in cpp_cnvt.awk coop-threads.h.cygnus \
123 coop-threads.c.cygnus mit-pthreads.h mit-pthreads.c fsu-pthreads.h
733943b9 124
fef07353 125## FIXME: Consider using timestamp file, to avoid unnecessary rebuilds.
90ff3ec5 126libpath.h: $(srcdir)/Makefile.in $(top_builddir)/config.status
e151bee6
JB
127 @echo "Generating libpath.h..."
128 @rm -f libpath.tmp
129 @echo '/* generated by Makefile */' > libpath.tmp
130 @echo '#define SCM_PKGDATA_DIR "$(pkgdatadir)"' >> libpath.tmp
131 @echo '#define SCM_LIBRARY_DIR "$(pkgdatadir)/$(VERSION)"'>>libpath.tmp
132 @echo '#define SCM_SITE_DIR "$(pkgdatadir)/site"' >> libpath.tmp
133 @echo '#define SCM_BUILD_INFO { \' >> libpath.tmp
134 @echo ' { "srcdir", "'"`cd @srcdir@; pwd`"'" }, \' >> libpath.tmp
135 @echo ' { "top_srcdir", "'"`cd @top_srcdir@; pwd`"'" }, \' \
136 >> libpath.tmp
137 @echo ' { "prefix", "@prefix@" }, \' >> libpath.tmp
138 @echo ' { "exec_prefix", "@exec_prefix@" }, \' >> libpath.tmp
139 @echo ' { "bindir", "@bindir@" }, \' >> libpath.tmp
140 @echo ' { "sbindir", "@sbindir@" }, \' >> libpath.tmp
141 @echo ' { "libexecdir", "@libexecdir@" }, \' >> libpath.tmp
142 @echo ' { "datadir", "@datadir@" }, \' >> libpath.tmp
143 @echo ' { "sysconfdir", "@sysconfdir@" }, \' >> libpath.tmp
144 @echo ' { "sharedstatedir", "@sharedstatedir@" }, \' >> libpath.tmp
145 @echo ' { "localstatedir", "@localstatedir@" }, \' >> libpath.tmp
146 @echo ' { "libdir", "@libdir@" }, \' >> libpath.tmp
147 @echo ' { "infodir", "@infodir@" }, \' >> libpath.tmp
148 @echo ' { "mandir", "@mandir@" }, \' >> libpath.tmp
149 @echo ' { "includedir", "@includedir@" }, \' >> libpath.tmp
150 @echo ' { "pkgdatadir", "$(datadir)/@PACKAGE@" }, \' >> libpath.tmp
151 @echo ' { "pkglibdir", "$(libdir)/@PACKAGE@" }, \' >> libpath.tmp
152 @echo ' { "pkgincludedir", "$(includedir)/@PACKAGE@" }, \' \
153 >> libpath.tmp
90ff3ec5 154 @echo ' { "LIBS", "@GUILE_LIBS@" }, \' >> libpath.tmp
e151bee6
JB
155 @echo '}' >> libpath.tmp
156 @mv libpath.tmp libpath.h
733943b9 157
3dc81fba
GB
158
159# ./guile-snarf $(DEFS) $(INCLUDES) $(CPPFLAGS) $(CFLAGS) $< > $@
160
161SUFFIXES = .x .doc
733943b9 162.c.x:
e8e9b690 163 ./guile-doc-snarf $< $(DEFS) $(INCLUDES) $(CPPFLAGS) $(CFLAGS) $< > $@ \
95042d95 164 || { rm $@; false; }
3dc81fba
GB
165.c.doc:
166 ./guile-doc-snarf $< $(DEFS) $(INCLUDES) $(CPPFLAGS) $(CFLAGS) $< \
167 || { rm $@; false; }
733943b9 168
4079f87e
GB
169## GJB:FIXME:: this is ugly; generate the *.doc files from the *.x file list, above
170guile-procedures.txt: *.doc
171 cat *.doc > $@
172
173pkgdata_DATA = guile-procedures.txt
174
733943b9
TT
175## Add -MG to make the .x magic work with auto-dep code.
176MKDEP = gcc -M -MG $(DEFS) $(INCLUDES) $(CPPFLAGS) $(CFLAGS)
ee78fbb0 177
a0e90145
JB
178cpp_err_symbols.c: cpp_err_symbols.in
179 $(AWK) -f $(srcdir)/cpp_cnvt.awk < $(srcdir)/cpp_err_symbols.in > \
593d151f
JB
180 cpp_err_symbols.tmp
181 mv cpp_err_symbols.tmp cpp_err_symbols.c
ee78fbb0 182
a0e90145
JB
183cpp_sig_symbols.c: cpp_sig_symbols.in
184 $(AWK) -f $(srcdir)/cpp_cnvt.awk < $(srcdir)/cpp_sig_symbols.in > \
593d151f
JB
185 cpp_sig_symbols.tmp
186 mv cpp_sig_symbols.tmp cpp_sig_symbols.c
67ec3667 187
a0e90145 188## Create a new version of the cpp_sig_symbols.in file, including all SIGXXX
67ec3667
GH
189## macros defined on this platform.
190check_signals:
191 gcc -undef -dM -E $(srcdir)/cpp_signal.c | egrep ' SIG[A-Z]+' \
192 | cut -f2 -d' ' | sort > cpp_sig_symbols_here
a0e90145
JB
193 diff -u $(srcdir)/cpp_sig_symbols.in cpp_sig_symbols_here \
194 | egrep '^\+S' \
67ec3667
GH
195 | cut -c2- > cpp_sig_symbols_diff
196 if test -s cpp_sig_symbols_diff ; then \
a0e90145 197 cat $(srcdir)/cpp_sig_symbols.in cpp_sig_symbols_diff \
67ec3667
GH
198 | sort > cpp_sig_symbols_new ;\
199 echo "cpp_sig_symbols_new has the following additions:" ;\
200 cat cpp_sig_symbols_diff ;\
201 else echo "No new symbols found."; \
202 fi
203
a0e90145 204## Likewise for cpp_err_symbols.in.
67ec3667
GH
205check_errnos:
206 gcc -undef -dM -E $(srcdir)/cpp_errno.c | egrep ' E.+' \
207 | cut -f2 -d' ' | sort > cpp_err_symbols_here
a0e90145
JB
208 diff -u $(srcdir)/cpp_err_symbols.in cpp_err_symbols_here \
209 | egrep '^\+E' \
67ec3667
GH
210 | cut -c2- > cpp_err_symbols_diff
211 if test -s cpp_err_symbols_diff ; then \
a0e90145 212 cat $(srcdir)/cpp_err_symbols.in cpp_err_symbols_diff \
67ec3667
GH
213 | sort > cpp_err_symbols_new ;\
214 echo "cpp_err_symbols_new has the following additions:" ;\
215 cat cpp_err_symbols_diff ;\
216 else echo "No new symbols found."; \
217 fi
218
ad6b30a0
TP
219MOSTLYCLEANFILES = \
220 cpp_err_symbols_here cpp_err_symbols_diff cpp_err_symbols_new \
67ec3667 221 cpp_sig_symbols_here cpp_sig_symbols_diff cpp_sig_symbols_new
ad6b30a0 222
553bb641 223CLEANFILES = libpath.h
ad6b30a0
TP
224
225DISTCLEANFILES = *.x
226