X-Git-Url: http://git.uio.no/git/?a=blobdiff_plain;f=build%2Fmodule.tpl;h=be324b21c8c47d3993286fc46fce74b77d6a3c74;hb=7b209ab25077a3ddc8556bca57db275f1fbe3436;hp=4029c1a235ec7447e262952234f74d2186013ffc;hpb=fe250300d94bff615c698a79ca196a3449d7dd10;p=u%2Fmrichter%2FAliRoot.git diff --git a/build/module.tpl b/build/module.tpl index 4029c1a235e..be324b21c8c 100644 --- a/build/module.tpl +++ b/build/module.tpl @@ -1,3 +1,4 @@ +#-*- Mode: Makefile -*- ifndef PACKFFLAGS @@ -32,14 +33,22 @@ else endif endif +ifndef PACKLDFLAGS +@PACKAGE@LDFLAGS:=$(LDFLAGS) +else +@PACKAGE@LDFLAGS:=$(PACKLDFLAGS) +endif + ifndef PACKDCXXFLAGS -ifeq ($(PLATFORM),linuxicc) -@PACKAGE@DCXXFLAGS:=$(filter-out -O%,$(CXXFLAGS)) -O0 +@PACKAGE@DCXXFLAGS:=$(CXXFLAGSNO) else -@PACKAGE@DCXXFLAGS:=$(filter-out -O%,$(CXXFLAGS)) +@PACKAGE@DCXXFLAGS:=$(PACKDCXXFLAGS) endif + +ifndef PACKBLIBS +@PACKAGE@BLIBS:=$(LIBS) else -@PACKAGE@DCXXFLAGS:=$(PACKCXXFLAGS) +@PACKAGE@BLIBS:=$(PACKBLIBS) endif @@ -56,11 +65,12 @@ endif #Extra include,libs, defines etc. -@PACKAGE@DEFINE:=$(EDEFINE) +@PACKAGE@DEFINE:=$(EDEFINE) -D__MODULE__=\"@MODULE@\" @PACKAGE@INC:=$(patsubst %,-I%,$(EINCLUDE)) -I@MODULE@ @PACKAGE@ELIBS:=$(patsubst %,-l%,$(ELIBS)) +@PACKAGE@ELIBSDEP:=$(patsubst %,lib/tgt_$(ALICE_TARGET)/lib%.$(SOEXT),$(ELIBS)) @PACKAGE@ELIBSDIR:=$(patsubst %,-L%,$(ELIBSDIR)) #c sources and headers @@ -81,22 +91,22 @@ endif # else use all headers ifndef CINTHDRS -@PACKAGE@CINTHDRS:=$(@PACKAGE@H) +@PACKAGE@CINTHDRS:=$(@PACKAGE@H) else @PACKAGE@CINTHDRS:=$(CINTHDRS) endif ############################################################################# # Package Dictionary - @PACKAGE@DH:=$(MODDIR)/$(DHDR) - #All objects +@PACKAGE@CXXO:=$(patsubst %,$(MODDIRO)/%, $(SRCS:.cxx=.o)) @PACKAGE@CO:=$(patsubst %,$(MODDIRO)/%, $(CSRCS:.c=.o)) -TEMP:=$(FSRCS:.F=.o) -@PACKAGE@FO:=$(patsubst %,$(MODDIRO)/%, $(TEMP:.f=.o)) -@PACKAGE@O:= $(patsubst %,$(MODDIRO)/%, $(SRCS:.cxx=.o)) $(@PACKAGE@FO) $(@PACKAGE@CO) +@PACKAGE@SMALLFO:=$(patsubst %.f,$(MODDIRO)/%.o, $(filter %.f, $(FSRCS))) +@PACKAGE@CAPITFO:=$(patsubst %.F,$(MODDIRO)/%.o, $(filter %.F, $(FSRCS))) +@PACKAGE@FO:=$(@PACKAGE@SMALLFO) $(@PACKAGE@CAPITFO) +@PACKAGE@O:= $(@PACKAGE@CXXO) $(@PACKAGE@FO) $(@PACKAGE@CO) @@ -156,7 +166,7 @@ else @PACKAGE@LIB := $(@PACKAGE@LIB) endif -# include all dependency files +# include all dependence files INCLUDEFILES +=$(@PACKAGE@DEP) EXPORTFILES += $(@PACKAGE@EXPORTDEST) @@ -172,24 +182,32 @@ $(@PACKAGE@EXPORTDEST): $(EXPORTDIR)/%.h: @MODULE@/%.h ifndef ALIQUIET @echo "***** Copying file $^ to $@ *****" endif - @[ -d $(dir $@) ] || mkdir $(dir $@) + @[ -d $(dir $@) ] || mkdir -p $(dir $@) @cp $^ $@ endif #------------------------------------------------------------------------ +ifneq (,$(findstring macosx,$(ALICE_TARGET))) +$(@PACKAGE@LIB): $(@PACKAGE@DLIB) $(@PACKAGE@O) $(@PACKAGE@DO) @MODULE@/module.mk +ifndef ALIQUIET + @echo "***** Linking library $@ *****" +endif + $(MUTE)rm -f $@; cd $(dir $@); ln -s $(notdir $(@PACKAGE@DLIB)) $(notdir $@) +else $(@PACKAGE@LIB):$(@PACKAGE@O) $(@PACKAGE@DO) @MODULE@/module.mk ifndef ALIQUIET @echo "***** Linking library $@ *****" endif $(MUTE)TMPDIR=/tmp/@MODULE@$$$$.`date +%M%S` ; \ - export TMPDIR; mkdir $$TMPDIR ; cd $$TMPDIR ; \ + export TMPDIR; mkdir -p $$TMPDIR ; cd $$TMPDIR ; \ find $(CURDIR)/@MODULE@/tgt_$(ALICE_TARGET) -name '*.o' -exec ln -s {} . \; ;\ - rm -f $(CURDIR)/$@ ;\ + \rm -f $(CURDIR)/$@ ;\ TMPLIB=$(notdir $(@PACKAGE@LIB)); export TMPLIB;\ $(SHLD) $(@PACKAGE@SOFLAGS) -o $(CURDIR)/$@ $(notdir $(@PACKAGE@O) $(@PACKAGE@DO)) $(@PACKAGE@ELIBSDIR) $(@PACKAGE@ELIBS) $(SHLIB);\ chmod a-w $(CURDIR)/$@ ;\ cd $(ALICE_ROOT) ; \rm -rf $$TMPDIR +endif ifneq ($(DYEXT),) $(@PACKAGE@DLIB):$(@PACKAGE@O) $(@PACKAGE@DO) @MODULE@/module.mk @@ -197,7 +215,7 @@ ifndef ALIQUIET @echo "***** Linking library $@ *****" endif $(MUTE)TMPDIR=/tmp/@MODULE@$$$$.`date +%M%S` ; \ - export TMPDIR; mkdir $$TMPDIR ; cd $$TMPDIR ; \ + export TMPDIR; mkdir -p $$TMPDIR ; cd $$TMPDIR ; \ find $(CURDIR)/@MODULE@/tgt_$(ALICE_TARGET) -name '*.o' -exec ln -s {} . \; ;\ \rm -f $(CURDIR)/$@ ;\ $(DYLD) $(@PACKAGE@DYFLAGS) -o $(CURDIR)/$@ $(notdir $(@PACKAGE@O) $(@PACKAGE@DO)) $(@PACKAGE@ELIBSDIR) $(@PACKAGE@ELIBS) $(DYLIB);\ @@ -212,11 +230,12 @@ ifndef ALIQUIET @echo "***** Linking static library $@ *****" endif $(MUTE)TMPDIR=/tmp/@MODULE@$$$$.`date +%M%S` ; \ - export TMPDIR; mkdir $$TMPDIR ; cd $$TMPDIR ; \ + export TMPDIR; mkdir -p $$TMPDIR ; cd $$TMPDIR ; \ find $(CURDIR)/@MODULE@/tgt_$(ALICE_TARGET) -name '*.o' -exec ln -s {} . \; ;\ - rm -f $(CURDIR)/$@ ;\ - $(ALLD) $(ALFLAGS) $(CURDIR)/$@ $(notdir $(@PACKAGE@O)) $(notdir @PACKAGE@DO) $(ALLIB);\ - cd $(CURDIR) ; rm -rf $$TMPDIR + \rm -f $(CURDIR)/$@ ;\ + TMPLIB=$(notdir $(@PACKAGE@LIB)); export TMPLIB;\ + $(ALLD) $(ALFLAGS) $(CURDIR)/$@ $(notdir $(@PACKAGE@O) $(@PACKAGE@DO)) $(@PACKAGE@ELIBSDIR) $(@PACKAGE@ELIBS) $(ALLIB);\ + cd $(CURDIR) ; \rm -rf $$TMPDIR $(MUTE)chmod a-w $@ @@ -225,23 +244,34 @@ ifndef ALIQUIET @echo "***** Making executable $@ *****" endif ifeq ($(ALIPROFILE),YES) - $(MUTE)$(LD) $(LDFLAGS) $(@PACKAGE@O) $(ARLIBS) $(SHLIBS) $(LIBS) $(EXEFLAGS) -o $@ + $(MUTE)$(LD) $(@PACKAGE@LDFLAGS) $(@PACKAGE@O) $(ARLIBS) $(SHLIBS) $(@PACKAGE@BLIBS) $(EXEFLAGS) -o $@ else - $(MUTE)$(LD) $(LDFLAGS) $(@PACKAGE@O) $(@PACKAGE@DO) $(BINLIBDIRS) $(@PACKAGE@ELIBSDIR) $(@PACKAGE@ELIBS) $(LIBS) $(EXEFLAGS) -o $@ + $(MUTE)$(LD) $(@PACKAGE@LDFLAGS) $(@PACKAGE@O) $(@PACKAGE@DO) $(BINLIBDIRS) $(@PACKAGE@ELIBSDIR) $(@PACKAGE@ELIBS) $(@PACKAGE@BLIBS) $(EXEFLAGS) -o $@ endif -$(@PACKAGE@DS): $(@PACKAGE@CINTHDRS) $(@PACKAGE@DH) @MODULE@/module.mk +$(@PACKAGE@DS): $(@PACKAGE@CINTHDRS) $(@PACKAGE@DH) @MODULE@/module.mk @MODULE@/tgt_$(ALICE_TARGET)/@PACKAGE@_srcslist ifndef ALIQUIET - @echo "***** Creating $@ *****"; + @echo "***** Creating $@ *****"; endif @(if [ ! -d '$(dir $@)' ]; then echo "***** Making directory $(dir $@) *****"; mkdir -p $(dir $@); fi;) - $(MUTE)rootcint -f $@ -c $(@PACKAGE@DEFINE) $(CINTFLAGS) $(@PACKAGE@INC) $(@PACKAGE@CINTHDRS) $(@PACKAGE@DH) + @\rm -f $(patsubst %.cxx,%.d, $@) + $(MUTE)rootcint -f $@ -c $(@PACKAGE@DEFINE) $(CINTFLAGS) $(@PACKAGE@INC) $(@PACKAGE@CINTHDRS) $(@PACKAGE@DH) -$(@PACKAGE@DO): $(@PACKAGE@DS) +$(@PACKAGE@DO): $(@PACKAGE@DS) ifndef ALIQUIET @echo "***** Compiling $< *****"; endif - $(MUTE)$(CXX) -c $(@PACKAGE@INC) -I$(ALICE_ROOT) $< -o $@ $(@PACKAGE@DCXXFLAGS) + $(MUTE)$(CXX) $(@PACKAGE@DEFINE) -c $(@PACKAGE@INC) -I$(ALICE_ROOT) $< -o $@ $(@PACKAGE@DCXXFLAGS) + +$(MODDIRO)/@PACKAGE@_srcslist: @MODULE@/@TYPE@@PACKAGE@.pkg + $(MUTE)if [ ! -d '$(dir $@)' ]; then echo "***** Making directory $(dir $@) *****"; mkdir -p $(dir $@); fi + $(MUTE)for i in $(@PACKAGE@CS) $(@PACKAGE@S) xyz; do echo $$i; done | sort > $@.new + $(MUTE)for j in `diff -w $@ $@.new 2>/dev/null | awk '/^\/dev/null 2>&1 $@ $@.new ;\ + if [ $$? -ne 0 ]; then \mv $@.new $@; else \rm $@.new; fi #Different targets for the module @@ -257,35 +287,28 @@ endif depend-@PACKAGE@: $(@PACKAGE@DEP) # determination of object files -$(MODDIRO)/%.o: $(MODDIRO)/%.cxx $(MODDIRO)/%.d -ifndef ALIQUIET - @echo "***** Compiling $< *****"; -endif - @(if [ ! -d '$(dir $@)' ]; then echo "***** Making directory $(dir $@) *****"; mkdir -p $(dir $@); fi;) - $(MUTE)$(CXX) $(@PACKAGE@DEFINE) -c $(@PACKAGE@INC) $< -o $@ $(@PACKAGE@CXXFLAGS) - -$(MODDIRO)/%.o: $(MODDIR)/%.cxx $(MODDIRO)/%.d +$(@PACKAGE@CXXO): $(MODDIRO)/%.o: $(MODDIR)/%.cxx $(MODDIRO)/%.d ifndef ALIQUIET @echo "***** Compiling $< *****"; endif @(if [ ! -d '$(dir $@)' ]; then echo "***** Making directory $(dir $@) *****"; mkdir -p $(dir $@); fi;) $(MUTE)$(CXX) $(@PACKAGE@DEFINE) -c $(@PACKAGE@INC) $< -o $@ $(@PACKAGE@CXXFLAGS) -$(MODDIRO)/%.o: $(MODDIR)/%.F $(MODDIRO)/%.d +$(@PACKAGE@CAPITFO): $(MODDIRO)/%.o: $(MODDIR)/%.F $(MODDIRO)/%.d ifndef ALIQUIET @echo "***** Compiling $< *****"; endif @(if [ ! -d '$(dir $@)' ]; then echo "***** Making directory $(dir $@) *****"; mkdir -p $(dir $@); fi;) $(MUTE)$(F77) -c $(@PACKAGE@INC) $< -o $@ $(@PACKAGE@FFLAGS) -$(MODDIRO)/%.o: $(MODDIR)/%.f $(MODDIRO)/%.d +$(@PACKAGE@SMALLFO): $(MODDIRO)/%.o: $(MODDIR)/%.f $(MODDIRO)/%.d ifndef ALIQUIET @echo "***** Compiling $< *****"; endif @(if [ ! -d '$(dir $@)' ]; then echo "***** Making directory $(dir $@) *****"; mkdir -p $(dir $@); fi;) $(MUTE)$(F77) -c $(@PACKAGE@INC) $< -o $@ $(@PACKAGE@FFLAGS) -$(MODDIRO)/%.o: $(MODDIR)/%.c $(MODDIRO)/%.d +$(@PACKAGE@CO): $(MODDIRO)/%.o: $(MODDIR)/%.c $(MODDIRO)/%.d ifndef ALIQUIET @echo "***** Compiling $< *****"; endif @@ -294,50 +317,56 @@ endif $(@PACKAGE@DDEP): $(@PACKAGE@DS) ifndef ALIQUIET - @echo "***** Making dependencies for $< *****"; + @echo "***** Making dependences for $< *****"; endif @(if [ ! -d '$(dir $@)' ]; then echo "***** Making directory $(dir $@) *****"; mkdir -p $(dir $@); fi;) @share/alibtool depend "$(@PACKAGE@ELIBSDIR) $(@PACKAGE@INC) $(DEPINC) $<" > $@ -$(MODDIRO)/%.d: $(MODDIRS)/%.cxx +$(@PACKAGE@CXXO:.o=.d): $(MODDIRO)/%.d: $(MODDIRS)/%.cxx ifndef ALIQUIET - @echo "***** Making dependencies for $< *****"; + @echo "***** Making dependences for $< *****"; endif @(if [ ! -d '$(dir $@)' ]; then echo "***** Making directory $(dir $@) *****"; mkdir -p $(dir $@); fi;) @share/alibtool depend "$(@PACKAGE@DEFINE) $(@PACKAGE@ELIBSDIR) $(@PACKAGE@INC) $(DEPINC) $<" > $@ -$(MODDIRO)/%.d: $(MODDIRS)/%.f + +$(@PACKAGE@SMALLFO:.o=.d): $(MODDIRO)/%.d: $(MODDIRS)/%.f ifndef ALIQUIET - @echo "***** Making dependencies for $< *****"; + @echo "***** Making dependences for $< *****"; endif @(if [ ! -d '$(dir $@)' ]; then echo "***** Making directory $(dir $@) *****"; mkdir -p $(dir $@); fi;) @share/alibtool dependF "$(@PACKAGE@ELIBSDIR) $(@PACKAGE@INC) $(DEPINC) $<" > $@ -$(MODDIRO)/%.d: $(MODDIRS)/%.F + +$(@PACKAGE@CAPITFO:.o=.d): $(MODDIRO)/%.d: $(MODDIRS)/%.F ifndef ALIQUIET - @echo "***** Making dependencies for $< *****"; + @echo "***** Making dependences for $< *****"; endif @(if [ ! -d '$(dir $@)' ]; then echo "***** Making directory $(dir $@) *****"; mkdir -p $(dir $@); fi;) $(MUTE)share/alibtool dependF "$(@PACKAGE@ELIBSDIR) $(@PACKAGE@INC) $(DEPINC) $<" > $@ -$(MODDIRO)/%.d: $(MODDIRS)/%.c + +$(@PACKAGE@CO:.o=.d): $(MODDIRO)/%.d: $(MODDIRS)/%.c ifndef ALIQUIET - @echo "***** Making dependencies for $< *****"; + @echo "***** Making dependences for $< *****"; endif @(if [ ! -d '$(dir $@)' ]; then echo "***** Making directory $(dir $@) *****"; mkdir -p $(dir $@); fi;) @share/alibtool depend "$(@PACKAGE@DEFINE) $(@PACKAGE@ELIBSDIR) $(@PACKAGE@INC) $(DEPINC) $<" > $@ -@PACKAGE@CHECKS := $(patsubst %.cxx,@PACKAGE@/check/%.viol,$(SRCS)) +.PRECIOUS: $(patsubst %.cxx,$(MODDIRO)/%.d,$(SRCS)) +.PRECIOUS: $(patsubst %.c,$(MODDIRO)/%.d,$(CSRCS)) +.PRECIOUS: $(patsubst %.F,$(MODDIRO)/%.d,$(patsubst %.f,$(MODDIRO)/%.d,$(FSRCS))) + +@PACKAGE@CHECKS := $(patsubst %.cxx,@MODULE@/check/%.viol,$(SRCS)) -check-@PACKAGE@: $(@PACKAGE@CHECKS) +check-@MODULE@: $(@PACKAGE@CHECKS) # IRST coding rule check -@PACKAGE@/check/%.i : @PACKAGE@/%.cxx +@MODULE@/check/%.i : @MODULE@/%.cxx @MODULE@/tgt_$(ALICE_TARGET)/%.d @[ -d $(dir $@) ] || mkdir -p $(dir $@) - $(MUTE)$(CXX) -E $(@PACKAGE@DEFINE) $(@PACKAGE@INC) $< > $@ $(@PACKAGE@CXXFLAGS) + $(MUTE)$(CXX) -E $(@PACKAGE@DEFINE) $(@PACKAGE@INC) -I. $< > $@ $(@PACKAGE@CXXFLAGS) @cd $(dir $@) ; $(IRST_INSTALLDIR)/patch/patch4alice.prl $(notdir $@) # IRST coding rule check -@PACKAGE@/check/%.viol : @PACKAGE@/check/%.i - @cd @PACKAGE@ ; [ -r @PACKAGE@ ] || ln -s ../@PACKAGE@ @PACKAGE@ - -@echo $@ ; $(CODE_CHECK) $< ./@PACKAGE@ > $@ +@MODULE@/check/%.viol : @MODULE@/check/%.i + $(MUTE)echo $@ ; $(CODE_CHECK) $< $(shell echo $(dir $<) | sed -e 's:/check::') > $@ @PACKAGE@PREPROC = $(patsubst %.viol,%.i,$(@PACKAGE@CHECKS)) @@ -345,15 +374,58 @@ check-@PACKAGE@: $(@PACKAGE@CHECKS) .SECONDARY: $(@PACKAGE@REVENGS) $(@PACKAGE@PREPROC) -reveng-@PACKAGE@: @PACKAGE@/check/classDiagram.dot +PACKREVENG += $(@PACKAGE@PREPROC) + +# IRST code smell checker + +@PACKAGE@SMELL := $(patsubst %.cxx,@MODULE@/smell/%.smell,$(SRCS)) + +smell-@MODULE@: $(@PACKAGE@SMELL) + +@MODULE@/smell/%_cxx.ml : @MODULE@/%.cxx + @[ -d $(dir $@) ] || mkdir -p $(dir $@) + $(MUTE)src2srcml $< $@ + +@MODULE@/smell/%_h.ml : @MODULE@/%.h + @[ -d $(dir $@) ] || mkdir -p $(dir $@) + $(MUTE)src2srcml $< $@ + +@MODULE@/smell/%.smell : @MODULE@/smell/%_cxx.ml @MODULE@/smell/%_h.ml + $(MUTE)echo smelling $@ + java -classpath $(SMELL_DETECTOR_DIR):$(SMELL_DETECTOR_DIR)/xom-1.1.jar -Xmx500m SmellDetector $? > $@ + +.PRECIOUS: $(patsubst %.cxx,@MODULE@/smell/%_h.ml,$(SRCS)) $(patsubst %.cxx,@MODULE@/smell/%_cxx.ml,$(SRCS)) + +# targets to create .par archives (jgrosseo) +@PACKAGE@.par: $(patsubst %,@MODULE@/@PACKAGE@/%,$(filter-out dict.%, $(HDRS) $(SRCS) $(DHDR) $(PKGFILE) Makefile Makefile.arch lib@PACKAGE@.pkg PROOF-INF)) + @echo "Creating archive" $@ ... + @cd @MODULE@; tar cfzh ../$@ @PACKAGE@ + @rm -rf @MODULE@/@PACKAGE@ + @echo "done" -@PACKAGE@/check/classDiagram.dot: $(@PACKAGE@PREPROC) - @$(REV_ENG) $^ - @-mv classDiagram.dot $@ +@MODULE@/@PACKAGE@/Makefile: @MODULE@/Makefile + @echo Copying $< to $@ with transformations + @[ -d $(dir $@) ] || mkdir -p $(dir $@) + @sed 's/include \$$(ROOTSYS)\/test\/Makefile.arch/include Makefile.arch/; s/PACKAGE = .*/PACKAGE = @PACKAGE@/' < $^ > $@ -revdisp-@PACKAGE@: reveng-@PACKAGE@ - @echo revdisp for @PACKAGE@ - @cd @PACKAGE@/check ; \ - $(IRST_INSTALLDIR)/webreveng/create-class-diagram-pages.sh - @sed -e "s/\@PACKAGE\@/@PACKAGE@/g" < $(ALICE_ROOT)/build/HomePage.html > @PACKAGE@/check/HomePage.html +@MODULE@/@PACKAGE@/Makefile.arch: $(ROOTSYS)/test/Makefile.arch + @echo Copying $< to $@ + @[ -d $(dir $@) ] || mkdir -p $(dir $@) + @cp -a $^ $@ +@MODULE@/@PACKAGE@/PROOF-INF: @MODULE@/PROOF-INF.@PACKAGE@ + @echo Copying $< to $@ + @[ -d $(dir $@) ] || mkdir -p $(dir $@) + @cp -a $^ $@ + +@MODULE@/@PACKAGE@/%: @MODULE@/% + @echo Copying $< to $@ + @[ -d $(dir $@) ] || mkdir -p $(dir $@) + @cp -a $< $@ + +test-@PACKAGE@.par: @PACKAGE@.par + @echo "INFO: The file $< is now tested, in case of an error check in par-tmp/@PACKAGE@." + @mkdir -p par-tmp + @cd par-tmp; tar xfz ../$<; cd $(subst .par,,$<); PROOF-INF/BUILD.sh + @rm -rf par-tmp/@PACKAGE@ + @echo "INFO: Testing succeeded (already cleaned up)"