Commit | Line | Data |
---|---|---|
733943b9 | 1 | ## Process this file with Automake to create Makefile.in |
2764bd99 | 2 | ## |
b0e5fd8c | 3 | ## Copyright (C) 1998, 1999, 2000, 2001 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 | 21 | |
3307df95 | 22 | AUTOMAKE_OPTIONS = gnu |
733943b9 | 23 | |
a0599745 | 24 | ## Prevent automake from adding extra -I options |
8f99e3f3 | 25 | DEFS = @DEFS@ |
733943b9 TT |
26 | ## Check for headers in $(srcdir)/.., so that #include |
27 | ## <libguile/MUMBLE.h> will find MUMBLE.h in this dir when we're | |
28 | ## building. | |
fc7c27fd | 29 | INCLUDES = -I.. -I$(srcdir)/.. ${INCLTDL} |
733943b9 | 30 | |
4079f87e | 31 | ETAGS_ARGS = --regex='/SCM_\(GLOBAL_\)?\(G?PROC\|G?PROC1\|SYMBOL\|VCELL\|CONST_LONG\).*\"\([^\"]\)*\"/\3/' \ |
abc049a9 | 32 | --regex='/[ \t]*SCM_[G]?DEFINE1?[ \t]*(\([^,]*\),[^,]*/\1/' |
fef07353 | 33 | |
e13d8dc0 | 34 | lib_LTLIBRARIES = libguile.la |
c99f9605 | 35 | bin_PROGRAMS = guile guile_filter_doc_snarfage |
549436de JB |
36 | |
37 | guile_SOURCES = guile.c | |
8f99e3f3 | 38 | guile_LDADD = libguile.la |
6165ede3 | 39 | guile_LDFLAGS = @DLPREOPEN@ |
ee2a8b9b | 40 | |
ac13d9d2 | 41 | guile_filter_doc_snarfage_SOURCES = c-tokenize.c |
c99f9605 | 42 | |
438b2738 MV |
43 | libguile_la_SOURCES = alist.c arbiters.c async.c backtrace.c boolean.c \ |
44 | chars.c continuations.c debug.c deprecation.c dynl.c dynwind.c \ | |
45 | environments.c eq.c error.c eval.c evalext.c extensions.c \ | |
46 | feature.c fluids.c fports.c \ | |
47 | gc.c gc_os_dep.c gdbint.c gh_data.c gh_eval.c gh_funcs.c gh_init.c \ | |
48 | gh_io.c gh_list.c gh_predicates.c goops.c gsubr.c guardians.c hash.c \ | |
49 | hashtab.c hooks.c init.c ioext.c iselect.c keywords.c lang.c list.c \ | |
50 | load.c macros.c mallocs.c modules.c numbers.c objects.c objprop.c \ | |
51 | options.c pairs.c ports.c print.c procprop.c procs.c properties.c \ | |
52 | random.c rdelim.c read.c root.c rw.c scmsigs.c script.c simpos.c smob.c \ | |
53 | sort.c srcprop.c stackchk.c stacks.c stime.c strings.c strop.c \ | |
6b41a313 | 54 | strorder.c strports.c struct.c symbols.c throw.c values.c \ |
dee01b01 | 55 | variable.c vectors.c version.c vports.c weaks.c |
03416a99 | 56 | |
7e516288 MV |
57 | DOT_X_FILES = alist.x arbiters.x async.x backtrace.x boolean.x chars.x \ |
58 | continuations.x debug.x deprecation.x dynl.x dynwind.x \ | |
59 | environments.x eq.x \ | |
438b2738 MV |
60 | error.x eval.x evalext.x extensions.x feature.x fluids.x fports.x \ |
61 | gc.x goops.x \ | |
7e516288 MV |
62 | gsubr.x guardians.x hash.x hashtab.x hooks.x init.x ioext.x iselect.x \ |
63 | keywords.x lang.x list.x load.x macros.x mallocs.x modules.x \ | |
64 | numbers.x objects.x objprop.x options.x pairs.x ports.x print.x \ | |
65 | procprop.x procs.x properties.x random.x rdelim.x read.x root.x rw.x \ | |
66 | scmsigs.x script.x simpos.x smob.x sort.x srcprop.x \ | |
67 | stackchk.x stacks.x stime.x strings.x strop.x strorder.x strports.x \ | |
6b41a313 | 68 | struct.x symbols.x throw.x values.x variable.x vectors.x \ |
dee01b01 | 69 | version.x vports.x weaks.x |
8bee78b3 | 70 | |
e9e225e5 | 71 | EXTRA_DOT_X_FILES = @EXTRA_DOT_X_FILES@ |
8bee78b3 | 72 | |
86d31dfe MV |
73 | DOT_DOC_FILES = alist.doc arbiters.doc async.doc backtrace.doc \ |
74 | boolean.doc chars.doc continuations.doc debug.doc dynl.doc \ | |
75 | dynwind.doc environments.doc eq.doc error.doc eval.doc evalext.doc \ | |
438b2738 MV |
76 | extensions.doc feature.doc fluids.doc fports.doc gc.doc goops.doc \ |
77 | gsubr.doc \ | |
86d31dfe MV |
78 | guardians.doc hash.doc hashtab.doc hooks.doc init.doc ioext.doc \ |
79 | iselect.doc keywords.doc lang.doc list.doc load.doc macros.doc \ | |
80 | mallocs.doc modules.doc numbers.doc objects.doc objprop.doc \ | |
81 | options.doc pairs.doc ports.doc print.doc procprop.doc \ | |
b0e5fd8c | 82 | procs.doc properties.doc random.doc rdelim.doc read.doc root.doc rw.doc \ |
86d31dfe MV |
83 | scmsigs.doc script.doc simpos.doc smob.doc sort.doc \ |
84 | srcprop.doc stackchk.doc stacks.doc stime.doc strings.doc strop.doc \ | |
6b41a313 | 85 | strorder.doc strports.doc struct.doc symbols.doc throw.doc \ |
dee01b01 | 86 | values.doc variable.doc vectors.doc version.doc vports.doc weaks.doc |
a3365d47 | 87 | |
2ce88b54 | 88 | EXTRA_DOT_DOC_FILES = @EXTRA_DOT_DOC_FILES@ |
9515eae6 | 89 | |
5b03c15c | 90 | BUILT_SOURCES = cpp_err_symbols.c cpp_sig_symbols.c libpath.h scmconfig.h \ |
c99f9605 | 91 | $(DOT_X_FILES) $(EXTRA_DOT_X_FILES) |
9515eae6 | 92 | |
438b2738 | 93 | EXTRA_libguile_la_SOURCES = _scm.h \ |
60a059e6 | 94 | alloca.c inet_aton.c memmove.c putenv.c strerror.c \ |
438b2738 MV |
95 | threads.c regex-posix.c \ |
96 | filesys.c posix.c net_db.c socket.c \ | |
94b1762d | 97 | ramap.c unif.c debug-malloc.c mkstemp.c win32-uname.c win32-dirent.c |
7bfd3b9e | 98 | |
a8861fa0 MD |
99 | ## In next release, threads will be factored out of libguile. |
100 | ## Until then, the machine specific headers is a temporary kludge. | |
101 | OMIT_DEPENDENCIES = libguile.h ltdl.h \ | |
102 | axp.h hppa.h i386.h ksr.h m88k.h mips.h sparc.h vax.h | |
2ce88b54 | 103 | |
413a1367 ML |
104 | ## delete guile-snarf.awk from the installation bindir, in case it's |
105 | ## lingering there due to an earlier guile version not having been | |
106 | ## wiped out. | |
107 | install-exec-hook: | |
108 | rm -f $(bindir)/guile-snarf.awk | |
109 | ||
7bfd3b9e | 110 | ## This is kind of nasty... there are ".c" files that we don't want to |
1be6b49c ML |
111 | ## compile, since they are #included. So instead we list them here. |
112 | ## Perhaps we can deal with them normally once the merge seems to be | |
113 | ## working. | |
5437598b | 114 | noinst_HEADERS = coop-threads.c coop-threads.h coop.c \ |
94b1762d | 115 | num2integral.i.c num2float.i.c win32-uname.h win32-dirent.h |
7bfd3b9e | 116 | |
78bda5f3 | 117 | libguile_la_DEPENDENCIES = @LIBLOBJS@ |
8f99e3f3 | 118 | libguile_la_LIBADD = @LIBLOBJS@ $(LIBLTDL) $(THREAD_LIBS_LOCAL) |
94b1762d | 119 | libguile_la_LDFLAGS = -version-info @LIBGUILE_INTERFACE_CURRENT@:@LIBGUILE_INTERFACE_REVISION@:@LIBGUILE_INTERFACE_AGE@ -export-dynamic -no-undefined |
733943b9 | 120 | |
ee2a8b9b JB |
121 | # These are headers visible as <guile/mumble.h> |
122 | pkginclude_HEADERS = gh.h | |
123 | ||
733943b9 | 124 | # These are headers visible as <libguile/mumble.h>. |
5380de6b | 125 | modincludedir = $(includedir)/libguile |
03416a99 | 126 | modinclude_HEADERS = __scm.h alist.h arbiters.h async.h backtrace.h boolean.h \ |
7e516288 | 127 | chars.h continuations.h coop-defs.h debug.h debug-malloc.h deprecation.h \ |
03416a99 | 128 | dynl.h dynwind.h environments.h eq.h error.h eval.h evalext.h \ |
438b2738 MV |
129 | extensions.h feature.h filesys.h fluids.h fports.h gc.h \ |
130 | gdb_interface.h gdbint.h \ | |
03416a99 KN |
131 | goops.h gsubr.h guardians.h hash.h hashtab.h hooks.h init.h ioext.h \ |
132 | iselect.h keywords.h lang.h list.h load.h macros.h mallocs.h modules.h \ | |
133 | net_db.h numbers.h objects.h objprop.h options.h pairs.h ports.h posix.h \ | |
134 | regex-posix.h print.h procprop.h procs.h properties.h random.h ramap.h \ | |
b0e5fd8c | 135 | rdelim.h read.h root.h rw.h scmsigs.h validate.h script.h simpos.h smob.h \ |
03416a99 | 136 | snarf.h socket.h sort.h srcprop.h stackchk.h stacks.h stime.h strings.h \ |
6b41a313 | 137 | strop.h strorder.h strports.h struct.h symbols.h tags.h threads.h \ |
03416a99 | 138 | throw.h unif.h values.h variable.h vectors.h version.h vports.h weaks.h |
4725c298 | 139 | |
adb75a41 TT |
140 | ## This file is generated at configure time. That is why it is DATA |
141 | ## and not a header -- headers are included in the distribution. | |
733943b9 TT |
142 | modinclude_DATA = scmconfig.h |
143 | ||
c99f9605 ML |
144 | bin_SCRIPTS = guile-snarf guile-doc-snarf guile-snarf-docs \ |
145 | guile-snarf-docs-texi guile-func-name-check | |
adb75a41 | 146 | |
41973b48 MV |
147 | EXTRA_DIST = ChangeLog-gh ChangeLog-scm ChangeLog-threads \ |
148 | ChangeLog-1996-1999 ChangeLog-2000 cpp_signal.c \ | |
149 | cpp_errno.c cpp_err_symbols.in cpp_sig_symbols.in cpp_cnvt.awk \ | |
30e3be5a | 150 | c-tokenize.lex |
c99f9605 ML |
151 | # $(DOT_DOC_FILES) $(EXTRA_DOT_DOC_FILES) \ |
152 | # guile-procedures.txt guile.texi | |
733943b9 | 153 | |
fef07353 | 154 | ## FIXME: Consider using timestamp file, to avoid unnecessary rebuilds. |
90ff3ec5 | 155 | libpath.h: $(srcdir)/Makefile.in $(top_builddir)/config.status |
e151bee6 JB |
156 | @echo "Generating libpath.h..." |
157 | @rm -f libpath.tmp | |
158 | @echo '/* generated by Makefile */' > libpath.tmp | |
159 | @echo '#define SCM_PKGDATA_DIR "$(pkgdatadir)"' >> libpath.tmp | |
160 | @echo '#define SCM_LIBRARY_DIR "$(pkgdatadir)/$(VERSION)"'>>libpath.tmp | |
161 | @echo '#define SCM_SITE_DIR "$(pkgdatadir)/site"' >> libpath.tmp | |
162 | @echo '#define SCM_BUILD_INFO { \' >> libpath.tmp | |
163 | @echo ' { "srcdir", "'"`cd @srcdir@; pwd`"'" }, \' >> libpath.tmp | |
164 | @echo ' { "top_srcdir", "'"`cd @top_srcdir@; pwd`"'" }, \' \ | |
165 | >> libpath.tmp | |
166 | @echo ' { "prefix", "@prefix@" }, \' >> libpath.tmp | |
167 | @echo ' { "exec_prefix", "@exec_prefix@" }, \' >> libpath.tmp | |
168 | @echo ' { "bindir", "@bindir@" }, \' >> libpath.tmp | |
169 | @echo ' { "sbindir", "@sbindir@" }, \' >> libpath.tmp | |
170 | @echo ' { "libexecdir", "@libexecdir@" }, \' >> libpath.tmp | |
171 | @echo ' { "datadir", "@datadir@" }, \' >> libpath.tmp | |
172 | @echo ' { "sysconfdir", "@sysconfdir@" }, \' >> libpath.tmp | |
173 | @echo ' { "sharedstatedir", "@sharedstatedir@" }, \' >> libpath.tmp | |
174 | @echo ' { "localstatedir", "@localstatedir@" }, \' >> libpath.tmp | |
175 | @echo ' { "libdir", "@libdir@" }, \' >> libpath.tmp | |
176 | @echo ' { "infodir", "@infodir@" }, \' >> libpath.tmp | |
177 | @echo ' { "mandir", "@mandir@" }, \' >> libpath.tmp | |
178 | @echo ' { "includedir", "@includedir@" }, \' >> libpath.tmp | |
179 | @echo ' { "pkgdatadir", "$(datadir)/@PACKAGE@" }, \' >> libpath.tmp | |
180 | @echo ' { "pkglibdir", "$(libdir)/@PACKAGE@" }, \' >> libpath.tmp | |
181 | @echo ' { "pkgincludedir", "$(includedir)/@PACKAGE@" }, \' \ | |
182 | >> libpath.tmp | |
b6fae158 | 183 | @echo ' { "guileversion", "@GUILE_VERSION@" }, \' >> libpath.tmp |
9e86801e | 184 | @echo ' { "libguileinterface", "@LIBGUILE_INTERFACE@" }, \' >> libpath.tmp |
30dda257 | 185 | @echo ' { "LIBS", "@GUILE_LIBS@" }, \' >> libpath.tmp |
e151bee6 JB |
186 | @echo '}' >> libpath.tmp |
187 | @mv libpath.tmp libpath.h | |
733943b9 | 188 | |
3dc81fba | 189 | |
3dc81fba | 190 | SUFFIXES = .x .doc |
733943b9 | 191 | .c.x: |
c99f9605 | 192 | ./guile-snarf $(DEFS) $(INCLUDES) $(CPPFLAGS) $(CFLAGS) $< > $@ \ |
95042d95 | 193 | || { rm $@; false; } |
c99f9605 ML |
194 | .c.doc: |
195 | -(test -n "${AWK+set}" || AWK="@AWK@"; ${AWK} -f ./guile-func-name-check $<) | |
8b1d12c7 ML |
196 | (./guile-snarf-docs $(DEFS) $(INCLUDES) $(CPPFLAGS) $(CFLAGS) $< | \ |
197 | ./guile_filter_doc_snarfage --filter-snarfage) > $@ || { rm $@; false; } | |
733943b9 | 198 | |
c99f9605 ML |
199 | $(DOT_X_FILES) $(EXTRA_DOT_DOC_FILES): snarf.h guile-snarf.in |
200 | ||
94b1762d | 201 | $(DOT_DOC_FILES) $(EXTRA_DOT_DOC_FILES): snarf.h guile-snarf-docs.in guile_filter_doc_snarfage$(EXEEXT) |
66418d34 | 202 | |
faf6a29b MV |
203 | error.x: cpp_err_symbols.c |
204 | posix.x: cpp_sig_symbols.c | |
205 | load.x: libpath.h | |
206 | ||
8b1d12c7 ML |
207 | guile.texi: $(DOT_DOC_FILES) $(EXTRA_DOT_DOC_FILES) guile-snarf-docs-texi.in guile |
208 | cat $(DOT_DOC_FILES) $(EXTRA_DOT_DOC_FILES) | ./guile-snarf-docs-texi > $@ \ | |
c99f9605 | 209 | || { rm $@; false; } |
9d29e990 NJ |
210 | |
211 | guile-procedures.txt: guile.texi | |
212 | rm -f $@ | |
213 | makeinfo --force -o $@ $< || test -f $@ | |
4079f87e | 214 | |
30e3be5a ML |
215 | c-tokenize.c: c-tokenize.lex |
216 | flex -t $< > $@ || { rm $@; false; } | |
217 | ||
8dc9439f MV |
218 | schemelibdir = $(pkgdatadir)/$(VERSION) |
219 | schemelib_DATA = guile-procedures.txt | |
4079f87e | 220 | |
733943b9 TT |
221 | ## Add -MG to make the .x magic work with auto-dep code. |
222 | MKDEP = gcc -M -MG $(DEFS) $(INCLUDES) $(CPPFLAGS) $(CFLAGS) | |
ee78fbb0 | 223 | |
a9c093e2 | 224 | cpp_err_symbols.c: cpp_err_symbols.in cpp_cnvt.awk |
a0e90145 | 225 | $(AWK) -f $(srcdir)/cpp_cnvt.awk < $(srcdir)/cpp_err_symbols.in > \ |
593d151f JB |
226 | cpp_err_symbols.tmp |
227 | mv cpp_err_symbols.tmp cpp_err_symbols.c | |
ee78fbb0 | 228 | |
a9c093e2 | 229 | cpp_sig_symbols.c: cpp_sig_symbols.in cpp_cnvt.awk |
a0e90145 | 230 | $(AWK) -f $(srcdir)/cpp_cnvt.awk < $(srcdir)/cpp_sig_symbols.in > \ |
593d151f JB |
231 | cpp_sig_symbols.tmp |
232 | mv cpp_sig_symbols.tmp cpp_sig_symbols.c | |
67ec3667 | 233 | |
a0e90145 | 234 | ## Create a new version of the cpp_sig_symbols.in file, including all SIGXXX |
67ec3667 GH |
235 | ## macros defined on this platform. |
236 | check_signals: | |
237 | gcc -undef -dM -E $(srcdir)/cpp_signal.c | egrep ' SIG[A-Z]+' \ | |
238 | | cut -f2 -d' ' | sort > cpp_sig_symbols_here | |
a0e90145 JB |
239 | diff -u $(srcdir)/cpp_sig_symbols.in cpp_sig_symbols_here \ |
240 | | egrep '^\+S' \ | |
67ec3667 GH |
241 | | cut -c2- > cpp_sig_symbols_diff |
242 | if test -s cpp_sig_symbols_diff ; then \ | |
a0e90145 | 243 | cat $(srcdir)/cpp_sig_symbols.in cpp_sig_symbols_diff \ |
67ec3667 GH |
244 | | sort > cpp_sig_symbols_new ;\ |
245 | echo "cpp_sig_symbols_new has the following additions:" ;\ | |
246 | cat cpp_sig_symbols_diff ;\ | |
247 | else echo "No new symbols found."; \ | |
248 | fi | |
249 | ||
a0e90145 | 250 | ## Likewise for cpp_err_symbols.in. |
67ec3667 GH |
251 | check_errnos: |
252 | gcc -undef -dM -E $(srcdir)/cpp_errno.c | egrep ' E.+' \ | |
253 | | cut -f2 -d' ' | sort > cpp_err_symbols_here | |
a0e90145 JB |
254 | diff -u $(srcdir)/cpp_err_symbols.in cpp_err_symbols_here \ |
255 | | egrep '^\+E' \ | |
67ec3667 GH |
256 | | cut -c2- > cpp_err_symbols_diff |
257 | if test -s cpp_err_symbols_diff ; then \ | |
a0e90145 | 258 | cat $(srcdir)/cpp_err_symbols.in cpp_err_symbols_diff \ |
67ec3667 GH |
259 | | sort > cpp_err_symbols_new ;\ |
260 | echo "cpp_err_symbols_new has the following additions:" ;\ | |
261 | cat cpp_err_symbols_diff ;\ | |
262 | else echo "No new symbols found."; \ | |
263 | fi | |
264 | ||
ad6b30a0 TP |
265 | MOSTLYCLEANFILES = \ |
266 | cpp_err_symbols_here cpp_err_symbols_diff cpp_err_symbols_new \ | |
67ec3667 | 267 | cpp_sig_symbols_here cpp_sig_symbols_diff cpp_sig_symbols_new |
ad6b30a0 | 268 | |
c99f9605 | 269 | CLEANFILES = libpath.h *.x *.doc guile-procedures.txt guile.texi |
ee0c0e03 ML |
270 | |
271 | MAINTAINERCLEANFILES = c-tokenize.c |