summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorRob Savoye <rob@welcomehome.org>2010-11-27 11:30:00 -0700
committerRob Savoye <rob@welcomehome.org>2010-11-27 11:30:00 -0700
commit93f9a98efb8dbfe48ba6cbe8325969e97fe840da (patch)
tree3105c6d450dfa4c77ce5513c3876e81ed21b6221
parent92098304def5782d2e1a0e6dec623595ab2e8f70 (diff)
build the generated filesystem and install it. Build libpath.h, needed by xyzzy-load.c to get it's path definitions.
-rw-r--r--gr-run-waveform/Makefile.am67
1 files changed, 63 insertions, 4 deletions
diff --git a/gr-run-waveform/Makefile.am b/gr-run-waveform/Makefile.am
index 13db3105db..a2040ec66d 100644
--- a/gr-run-waveform/Makefile.am
+++ b/gr-run-waveform/Makefile.am
@@ -21,24 +21,37 @@
ACLOCAL_AMFLAGS = -I config
DIST_SUBDIRS = config
-EXTRA_DIST = gen-xyzzy
+EXTRA_DIST = gen-xyzzy load.x
# build the standalone waveform application
bin_PROGRAMS = run_waveform
+# Rather than build a library, we just use a variable so the same code
+# can be used in test cases, as well as the run-waveform application.
+SRCS = xyzzy.cc # xyzzy-load.c
+
+# This is where the data file created by gen-xyzzy gets installed. This file
+# is needed by run-waveform and the test case.
+filesystemdir = $(datarootdir)/gnuradio/gr-run-waveform
+
+# libpath is to support xyzzy-load.c, filesystem.dat is the data file
+BUILT_SOURCES = libpath.h filesystem.dat
+dist_filesystem_DATA = filesystem.dat
+
# A unit test case for the XYZZY class
check_PROGRAMS = test_xyzzy
-test_xyzzy_SOURCES = test_xyzzy.cc xyzzy.cc
+test_xyzzy_SOURCES = test_xyzzy.cc $(SRCS)
test_xyzzy_CPPFLAGS = $(GUILE_CFLAGS) \
-DSRCDIR=\"$(srcdir)\" \
-DDATAROOTDIR=\"$(datarootdir)\"
test_xyzzy_LDADD = $(GUILE_LIBS)
+test_xyzzy_DEPENDENCIES = $(BUILT_SOURCES)
# Don't install the internal header
noinst_HEADERS = xyzzy.h
# The standalone waveform application
-run_waveform_SOURCES = run_waveform.cc xyzzy.cc
+run_waveform_SOURCES = run_waveform.cc $(SRCS)
run_waveform_CPPFLAGS = $(GUILE_CFLAGS) \
-DSRCDIR=\"$(srcdir)\" \
-DPKGLIBDIR=\"$(pkglibdir)\" \
@@ -47,5 +60,51 @@ run_waveform_CPPFLAGS = $(GUILE_CFLAGS) \
# Note that this will fail to link it you don't have libguile.a.
# run_waveform_LDFLAGS = -static
run_waveform_LDADD = $(GUILE_LIBS)
+run_waveform_DEPENDENCIES = $(BUILT_SOURCES)
+
+DISTCLEANFILES = gr-run-waveform.tar.gz libpath.h filesystem.dat
+
+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)/$(GUILE_EFFECTIVE_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", "@top_srcdir_absolute@" }, \' >> 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 ' { "guileversion", "@GUILE_VERSION@" }, \' >> libpath.tmp
+ @echo ' { "libguileinterface", "@LIBGUILE_INTERFACE@" }, \' \
+ >> libpath.tmp
+ @echo ' { "LIBS", "@GUILE_LIBS@" }, \' >> libpath.tmp
+ @echo ' { "CFLAGS", "@GUILE_CFLAGS@" }, \' >> libpath.tmp
+ @echo ' { "buildstamp", "'"`date`"'" }, \' >> libpath.tmp
+ @echo '}' >> libpath.tmp
+ @mv libpath.tmp libpath.h
-DISTCLEANFILES = gr-run-waveform.tar.gz
+# Typical usage:
+# gen-xyzzy -o filesystem.dat /usr/share/guile/1.8 /usr/local/share/guile/site
+# Where /usr/share/guile points to the system guile installation and
+# /usr/local/share/guile/site points to the GNU Radio installed guile files. Note
+# that this requires GNU Radio to be installed before the outout will be correct.
+filesystem.dat:
+ -$(RM) -f filesystem.dat
+ $(PYTHON) $(srcdir)/gen-xyzzy $(GUILE_INSTALL_PATH) $(datarootdir)/guile/site > filesystem.dat