From: Jens Thiele Date: Tue, 28 Nov 2006 12:49:05 +0000 (+0000) Subject: installation and .pc file generation X-Git-Tag: v0.2~79 X-Git-Url: http://developer.intra2net.com/git/?p=libt2n;a=commitdiff_plain;h=3c4dd222bdf18612d26250088c999dc0b2937dba;hp=3ac2ff0ef7ebaf06491641af65cf0a42f041fd0c installation and .pc file generation --- diff --git a/codegen/Makefile.am b/codegen/Makefile.am index 1f3846a..ca4aa36 100644 --- a/codegen/Makefile.am +++ b/codegen/Makefile.am @@ -4,3 +4,5 @@ LDADD = @CODEGEN_LIBS@ codegen_SOURCES = main.cpp bin_PROGRAMS = codegen + +EXTRA_DIST = clientlib.pc.in diff --git a/example-codegen/Makefile.am b/example-codegen/Makefile.am index db45e0c..1037dab 100644 --- a/example-codegen/Makefile.am +++ b/example-codegen/Makefile.am @@ -1,46 +1,52 @@ INCLUDES = -I$(top_srcdir)/src @BOOST_CPPFLAGS@ @CPPUNIT_CFLAGS@ -I$(top_srcdir)/codegen - LDADD = $(top_builddir)/src/libt2n.la @BOOST_SERIALIZATION_LIB@ @BOOST_LDFLAGS@ CMDGROUPS = default other default_GROUP = default.cpp +# command example of group using multiple cpp files other_GROUP = other-1.cpp other-2.cpp +# foo.hxx must be listed manually +include_HEADERS = foo.hxx + # unfortunately we can't set those from variables # because they are parsed by automake libdefault_la_SOURCES = default_client.cpp libother_la_SOURCES = other_client.cpp -noinst_LTLIBRARIES = libdefault.la libother.la +lib_LTLIBRARIES = libdefault.la libother.la + +# build an example server and client client_SOURCES = client.cpp client_LDADD = $(LDADD) libdefault.la libother.la - server_SOURCES = server.cpp \ $(other_GROUP) other_server.cpp \ $(default_GROUP) default_server.cpp \ foo.hxx - noinst_PROGRAMS = client server +# test script + +TESTS = test # always the same: +include_HEADERS += $(foreach i, $(CMDGROUPS), $(i)_client.hxx $(i).hxx) + #IFILES=$(foreach i, $(CMDGROUPS), $(foreach j, $($(i)_GROUP), $(j))) -STAMPS=$(CMDGROUPS:=.stamp) -GROUPDEP_FILES = $(foreach i, $(CMDGROUPS), .deps/group_$(i).P) --include $(GROUPDEP_FILES) +-include $(foreach i, $(CMDGROUPS), .deps/group_$(i).P) .deps/group_%.P : Makefile.am echo $@ : $($*_GROUP) > .deps/group_$*.P -%.stamp : .deps/group_%.P $(top_builddir)/codegen/codegen Makefile.am +%.stamp : .deps/group_%.P $(top_builddir)/codegen/codegen # assuming we have some unix like shell (maybe even bash) echo BUILT_SOURCES: $(BUILT_SOURCES) cp -v $(top_srcdir)/codegen/codegen-stubhead.hxx $*_common.hxx; - cp -v $(top_srcdir)/codegen/codegen-stubhead.hxx $*_server.hxx; + echo > $*_server.hxx; # todo use tmp file for xml file for i in $($*_GROUP); do \ gccxml $(DEFS) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS) $${i} -fxml=$${i%*.cpp}.xml; \ @@ -50,8 +56,22 @@ GROUPDEP_FILES = $(foreach i, $(CMDGROUPS), .deps/group_$(i).P) # assuming we have gnu make? BUILT_SOURCES = $(foreach i, $(CMDGROUPS), $(foreach j, _common.hxx _common.cpp _client.hxx _client.cpp _server.hxx _server.cpp, $(i)$(j)) ) +STAMPS=$(CMDGROUPS:=.stamp) $(BUILT_SOURCES) : $(STAMPS) -TESTS = test CLEANFILES = $(BUILT_SOURCES) $(STAMPS) + +# Install the pkg-config files: +pkgconfigdir = $(libdir)/pkgconfig +pkgconfig_DATA = $(CMDGROUPS:=.pc) + +# .pc files (one pc file for each command group) +%.pc : $(top_srcdir)/codegen/clientlib.pc.in Makefile + sed \ + -e 's,@CMDGROUP@,$*,g' \ + -e 's,\@prefix\@,$(prefix),g' \ + -e 's,\@exec_prefix\@,$(exec_prefix),g' \ + -e 's,\@libdir\@,$(libdir),g' \ + -e 's,\@includedir\@,$(includedir),g' \ + $< >$*.pc diff --git a/example-codegen/TODO b/example-codegen/TODO index cce81e0..40a8731 100644 --- a/example-codegen/TODO +++ b/example-codegen/TODO @@ -16,3 +16,5 @@ now we use the first solution - would be nice to reduce amount of changed files (codegen output is often the same as the existing files - something similar to ccache for codegen - but not overwriting output files if they are the same) +- howto include the part after "# always the same:" in all makefiles using the codegenerator +- lib name should be group name + suffix/prefix