X-Git-Url: http://developer.intra2net.com/git/?p=libt2n;a=blobdiff_plain;f=example-codegen%2FMakefile.am;h=4baab90ba22f357941d406a3aa2569a68383e207;hp=5deff2e35bc8d4f25fd69b9531b032c4948c173b;hb=1f5e9bdead71a72eb9c6b1945231f742bbccd728;hpb=63291e4f84b127b479bee0710860e5fdbfbd5b11 diff --git a/example-codegen/Makefile.am b/example-codegen/Makefile.am index 5deff2e..4baab90 100644 --- a/example-codegen/Makefile.am +++ b/example-codegen/Makefile.am @@ -2,23 +2,55 @@ INCLUDES = -I$(top_srcdir)/src @BOOST_CPPFLAGS@ @CPPUNIT_CFLAGS@ -I$(top_srcdir) LDADD = $(top_builddir)/src/libt2n.la @BOOST_SERIALIZATION_LIB@ @BOOST_LDFLAGS@ -libclient_la_SOURCES = codegen_client.cpp -noinst_LTLIBRARIES = libclient.la +CMDGROUPS = default other + +libdefault_la_SOURCES = default_client.cpp +libother_la_SOURCES = other_client.cpp +noinst_LTLIBRARIES = libdefault.la libother.la client_SOURCES = client.cpp -client_LDADD = $(LDADD) libclient.la +client_LDADD = $(LDADD) libdefault.la libother.la -server_SOURCES = server.cpp codegen_server.cpp foo.hxx +server_SOURCES = server.cpp \ + other.cpp other_server.cpp \ + default.cpp default_server.cpp \ + foo.hxx noinst_PROGRAMS = client server -codegen.stamp: server.hxx $(top_builddir)/codegen/codegen - cp $(top_srcdir)/codegen/codegen-stubhead.hxx codegen_common.hxx -# todo use tmp file for server.xml - gccxml $(DEFS) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS) $< -fxml=server.xml - $(top_builddir)/codegen/codegen $< server.xml codegen_ - touch $@ -codegen_common.hxx codegen_common.cpp codegen_client.hxx codegen_client.cpp codegen_server.cpp: codegen.stamp +# always the same: + +codegen.stamp: $(CMDGROUPS:%=%.cpp) $(top_builddir)/codegen/codegen +# assuming we have some unix like shell + echo BUILT_SOURCES: $(BUILT_SOURCES) + for i in $(CMDGROUPS); do \ + cp -v $(top_srcdir)/codegen/codegen-stubhead.hxx $${i}_common.hxx; \ + cp -v $(top_srcdir)/codegen/codegen-stubhead.hxx $${i}_server.hxx; \ + done +# todo use tmp file for xml file + for i in $(CMDGROUPS); do \ + gccxml $(DEFS) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS) $${i}.cpp -fxml=$${i}.xml; \ + $(top_builddir)/codegen/codegen $${i}.cpp $${i}.xml $${i}; \ + done; touch $@ + +# 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)) ) + +$(BUILT_SOURCES) : codegen.stamp TESTS = test + +CLEANFILES = codegen.stamp + +# TODO: +# howto generate Makefile(.in) from something like this: + +# CMDGROUPS = default other + +# default_SOURCES = default-1.cpp default-2.cpp +# other_SOURCES = other.cpp + +# TESTS = test + +# server_SOURCES = server.cpp default foo.hxx