X-Git-Url: http://developer.intra2net.com/git/?p=libt2n;a=blobdiff_plain;f=example-codegen%2FMakefile.am;h=ca49cb8deec9d717626623acc1f43508fe4baea9;hp=202f514698404d2b3429c863c1e71003f3e769dc;hb=86c3b9abe80f01be882fdc84f601e65e056006bb;hpb=4c298f07f2663a7c42fda686bcd4e5ccb38103c3 diff --git a/example-codegen/Makefile.am b/example-codegen/Makefile.am index 202f514..ca49cb8 100644 --- a/example-codegen/Makefile.am +++ b/example-codegen/Makefile.am @@ -1,69 +1,47 @@ -INCLUDES = -I$(top_srcdir)/src @BOOST_CPPFLAGS@ @CPPUNIT_CFLAGS@ -I$(top_srcdir)/codegen - -LDADD = $(top_builddir)/src/libt2n.la @BOOST_SERIALIZATION_LIB@ @BOOST_LDFLAGS@ +INCLUDES = @LIBT2N_CFLAGS@ +LDADD = @LIBT2N_LIBS@ +# list your command groups CMDGROUPS = default other +# for each command group list the files to parse for LIBT2N_EXPORT default_GROUP = default.cpp +# example of a command group using multiple cpp files other_GROUP = other-1.cpp other-2.cpp +# headers declaring data types used as rpc arguments must be listed manually +# (in this example the class Foo) +include_HEADERS = foo.hxx + # unfortunately we can't set those from variables # because they are parsed by automake +# and we can't use noinst since our automake version is to old +# (see dist-hook in codegen.make) 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 +server_SOURCES = \ + server.cpp $(other_GROUP) $(default_GROUP) \ + other_server.cpp default_server.cpp -# always the same: - -#IFILES=$(foreach i, $(CMDGROUPS), $(foreach j, $($(i)_GROUP), $(j))) -STAMPS=$(CMDGROUPS:=.stamp) - -GROUPDEP_FILES = $(foreach i, $(CMDGROUPS), .deps/group_$(i).P) --include $(GROUPDEP_FILES) - -.deps/group_%.P : Makefile.am - echo $@ : $($*_GROUP) > .deps/group_$*.P - -%.stamp : .deps/group_%.P $(top_builddir)/codegen/codegen Makefile.am -# 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; -# 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; \ - done; \ - $(top_builddir)/codegen/codegen $*.cpp $* $($*_GROUP:.cpp=.xml) && 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) : $(STAMPS) +# test script TESTS = test -CLEANFILES = $(BUILT_SOURCES) $(STAMPS) - -# TODO: -# howto generate Makefile(.in) from something like this: - -# CMDGROUPS = default other - -# default_SOURCES = default-1.cpp default-2.cpp -# other_SOURCES = other.cpp +EXTRA_DIST = $(TESTS) configure.in -# TESTS = test +# we have got an old automake version (1.4-p5) which doesn't support nodist_ +# => you might want to use the dist-hook to remove generated files +dist-hook: + rm -vf $(foreach i, $(BUILT_SOURCES), $(distdir)/$(i)) -# server_SOURCES = server.cpp default foo.hxx +# if you use codegen you should add the next line at the end +@LIBT2N_CODEGEN_MAKESNIPPET@