X-Git-Url: http://git.uio.no/git/?a=blobdiff_plain;f=build%2Fmodule.tpl;h=50d4b558bbf734262fbcf715ede4370cf642f5d5;hb=5b2e5faeb0218a2fa5ac178e2a61ac6d56cab371;hp=7c932acff11b43e6c4d2230495826179190b45fc;hpb=3b2d7a6f7c8075616ac81bc19b09ffd935a184bd;p=u%2Fmrichter%2FAliRoot.git diff --git a/build/module.tpl b/build/module.tpl index 7c932acff11..50d4b558bbf 100644 --- a/build/module.tpl +++ b/build/module.tpl @@ -25,14 +25,6 @@ else @PACKAGE@SOFLAGS:=$(PACKSOFLAGS) endif -ifdef DYEXT -ifndef PACKDYFLAGS -@PACKAGE@DYFLAGS:=$(DYFLAGS) -else -@PACKAGE@DYFLAGS:=$(PACKDYFLAGS) -endif -endif - ifndef PACKLDFLAGS @PACKAGE@LDFLAGS:=$(LDFLAGS) else @@ -51,11 +43,13 @@ else @PACKAGE@BLIBS:=$(PACKBLIBS) endif - -ifdef DHDR +WITHDICT= +ifneq ($(DHDR),) WITHDICT=YES else -WITHDICT= +ifneq ($(CINTAUTOLINK),) +WITHDICT=YES +endif endif # Headerfiles exported to common place: @@ -65,7 +59,7 @@ endif #Extra include,libs, defines etc. -@PACKAGE@DEFINE:=$(EDEFINE) -D__MODULE__=\"@MODULE@\" +@PACKAGE@DEFINE:=$(EDEFINE) -D_MODULE_=\"@MODULE@\" @PACKAGE@INC:=$(patsubst %,-I%,$(EINCLUDE)) -I@MODULE@ @@ -93,12 +87,22 @@ endif ifndef CINTHDRS @PACKAGE@CINTHDRS:=$(@PACKAGE@H) else -@PACKAGE@CINTHDRS:=$(CINTHDRS) +@PACKAGE@CINTHDRS:=$(CINTHDRS:%=@MODULE@/%) +#@PACKAGE@CINTHDRS:=$(pathsubst %,@MODULE@/%,$(CINTHDRS)) endif +@PACKAGE@CINTCLASSES:=$(patsubst %.h,%,$(notdir $(@PACKAGE@CINTHDRS))) ############################################################################# # Package Dictionary +ifneq ($(DHDR),) @PACKAGE@DH:=$(MODDIR)/$(DHDR) +else +@PACKAGE@DH:= +endif +ifneq ($(CINTAUTOLINK),) +@PACKAGE@DAL:=$(MODDIRO)/G__@PACKAGE@AutoLinkDef.h +@PACKAGE@DH+=$(@PACKAGE@DAL) +endif #All objects @PACKAGE@CXXO:=$(patsubst %,$(MODDIRO)/%, $(SRCS:.cxx=.o)) @@ -107,7 +111,8 @@ endif @PACKAGE@CAPITFO:=$(patsubst %.F,$(MODDIRO)/%.o, $(filter %.F, $(FSRCS))) @PACKAGE@FO:=$(@PACKAGE@SMALLFO) $(@PACKAGE@CAPITFO) @PACKAGE@O:= $(@PACKAGE@CXXO) $(@PACKAGE@FO) $(@PACKAGE@CO) - +@PACKAGE@CHV:=$(patsubst %,$(MODDIRC)/%, $(SRCS:.cxx=.viol)) +@PACKAGE@SML:=$(sort $(patsubst %,$(MODDIRZ)/%, $(filter $(SRCS:.cxx=.smell),$(HDRS:.h=.smell)))) ifdef WITHDICT @@ -127,17 +132,12 @@ endif @PACKAGE@LIB:=$(LIBPATH)/lib@PACKAGE@.$(SOEXT) -ifneq ($(DYEXT),) -@PACKAGE@DLIB:=$(LIBPATH)/lib@PACKAGE@.$(DYEXT) -endif - @PACKAGE@ALIB:=$(LIBPATH)/lib@PACKAGE@.$(AEXT) #Add this to the modules libs +ifeq ($(TYPE),lib) @MODULE@LIBS += $(@PACKAGE@LIB) @MODULE@ALIBS += $(@PACKAGE@ALIB) -ifneq ($(DYEXT),) -@MODULE@DLIBS += $(@PACKAGE@DLIB) endif #The actual binary file @@ -152,19 +152,12 @@ endif ifeq ($(TYPE),lib) ALLLIBS += $(@PACKAGE@LIB) ALLALIBS += $(@PACKAGE@ALIB) -ifneq ($(DYEXT),) -ALLLIBS += $(@PACKAGE@DLIB) -endif BINLIBS += -l@PACKAGE@ else ALLEXECS += $(@PACKAGE@BIN) endif -ifeq ($(DYEXT),) @PACKAGE@LIB := $(@PACKAGE@LIB) -else -@PACKAGE@LIB := $(@PACKAGE@LIB) -endif # include all dependence files INCLUDEFILES +=$(@PACKAGE@DEP) @@ -188,40 +181,15 @@ 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 -p $$TMPDIR ; cd $$TMPDIR ; \ - find $(CURDIR)/@MODULE@/tgt_$(ALICE_TARGET) -name '*.o' -exec ln -s {} . \; ;\ - \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 -ifndef ALIQUIET - @echo "***** Linking library $@ *****" -endif - $(MUTE)TMPDIR=/tmp/@MODULE@$$$$.`date +%M%S` ; \ - 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);\ - chmod a-w $(CURDIR)/$@ ;\ - cd $(ALICE_ROOT) ; \rm -rf $$TMPDIR -endif + \rm -f "$(CURDIR)"/$@ ;\ + cd $(@MODULE@DIRO) ;\ + $(SHLD) $(@PACKAGE@SOFLAGS) -o "$(CURDIR)"/$@ $(patsubst $(@MODULE@DIRO)/%,%,$(@PACKAGE@O) $(@PACKAGE@DO)) $(@PACKAGE@ELIBSDIR) $(@PACKAGE@ELIBS) $(SHLIB);\ + chmod a-w "$(CURDIR)"/$@ ;\ + cd $(ALICE_ROOT) #------------------------------------------------------------------------ @@ -229,14 +197,10 @@ $(@PACKAGE@ALIB):$(@PACKAGE@O) $(@PACKAGE@DO) @MODULE@/module.mk ifndef ALIQUIET @echo "***** Linking static library $@ *****" endif - $(MUTE)TMPDIR=/tmp/@MODULE@$$$$.`date +%M%S` ; \ - export TMPDIR; mkdir -p $$TMPDIR ; cd $$TMPDIR ; \ - find $(CURDIR)/@MODULE@/tgt_$(ALICE_TARGET) -name '*.o' -exec ln -s {} . \; ;\ - \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 $@ + \rm -f "$(CURDIR)"/$@ ;\ + cd $(@MODULE@DIRO) ;\ + $(ALLD) $(ALFLAGS) "$(CURDIR)"/$@ $(patsubst $(@MODULE@DIRO)/%,%,$(@PACKAGE@O) $(@PACKAGE@DO)) $(@PACKAGE@ELIBSDIR) $(@PACKAGE@ELIBS) $(ALLIB);\ + cd $(ALICE_ROOT) $(@PACKAGE@BIN):$(@PACKAGE@O) $(@PACKAGE@DO) @MODULE@/module.mk @@ -249,7 +213,26 @@ else $(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 @MODULE@/tgt_$(ALICE_TARGET)/@PACKAGE@_srcslist +$(@PACKAGE@DAL): $(@PACKAGE@CINTHDRS) @MODULE@/module.mk +ifndef ALIQUIET + @echo "***** Creating $@ *****"; +endif + $(MUTE)echo '//automatically generated ROOT DICT definition' > $@ + $(MUTE)echo '//!!! DO NOT EDIT THIS FILE !!!' >> $@ + $(MUTE)echo '#ifdef __CINT__' >> $@ + $(MUTE)echo '#pragma link off all globals;' >> $@ + $(MUTE)echo '#pragma link off all classes;' >> $@ + $(MUTE)echo '#pragma link off all functions;' >> $@ + $(MUTE)$(foreach i, $(@PACKAGE@CINTCLASSES), \ + echo "#pragma link C++ class $(i)+;" >> $@ ;) + $(MUTE)echo '#endif' >> $@ + +ifneq ($(findstring solaris,$(ALICE_TARGET)),) +# shameful hack.... +CINTFLAGS := $(filter-out -library=stlport4,$(CINTFLAGS)) +endif + +$(@PACKAGE@DS): $(@PACKAGE@CINTHDRS) $(@PACKAGE@DH) @MODULE@/module.mk ifndef ALIQUIET @echo "***** Creating $@ *****"; endif @@ -263,27 +246,16 @@ ifndef ALIQUIET endif $(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 ifeq ($(TYPE),lib) -all-@PACKAGE@: $(@PACKAGE@LIB) -ifneq ($(DYEXT),) -all-@PACKAGE@: $(@PACKAGE@DLIB) -endif +all-@MODULE@: $(@PACKAGE@LIB) else -all-@PACKAGE@: $(@PACKAGE@BIN) +all-@MODULE@: $(@PACKAGE@BIN) endif + depend-@PACKAGE@: $(@PACKAGE@DEP) # determination of object files @@ -354,34 +326,46 @@ endif .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-@MODULE@: $(@PACKAGE@CHECKS) +check-@MODULE@: $(@PACKAGE@CHV) # IRST coding rule check -@MODULE@/check/%.i : @MODULE@/%.cxx @MODULE@/tgt_$(ALICE_TARGET)/%.d +$(@PACKAGE@CHV:.viol=.i): $(MODDIRC)/%.i: $(MODDIR)/%.cxx $(MODDIRO)/%.d @[ -d $(dir $@) ] || mkdir -p $(dir $@) $(MUTE)$(CXX) -E $(@PACKAGE@DEFINE) $(@PACKAGE@INC) -I. $< > $@ $(@PACKAGE@CXXFLAGS) @cd $(dir $@) ; $(IRST_INSTALLDIR)/patch/patch4alice.prl $(notdir $@) # IRST coding rule check -@MODULE@/check/%.viol : @MODULE@/check/%.i +$(@PACKAGE@CHV): $(MODDIRC)/%.viol: $(MODDIRC)/%.i $(MUTE)echo $@ ; $(CODE_CHECK) $< $(shell echo $(dir $<) | sed -e 's:/check::') > $@ -@PACKAGE@PREPROC = $(patsubst %.viol,%.i,$(@PACKAGE@CHECKS)) +.SECONDARY: $(@PACKAGE@CHV:.viol=.i) $(@PACKAGE@CHI:.viol=.ii) + +PACKREVENG += $(@PACKAGE@CHV:.viol=.ii) -@PACKAGE@REVENGS = $(patsubst %.viol,%.ii,$(@PACKAGE@CHECKS)) +# IRST code smell checker + +smell-@MODULE@: $(@PACKAGE@SML) + +$(@PACKAGE@SML:.smell=_cxx.ml) : $(MODDIRZ)/%_cxx.ml : $(MODDIR)/%.cxx + @[ -d $(dir $@) ] || mkdir -p $(dir $@) + $(MUTE)src2srcml $< $@ + +$(@PACKAGE@SML:.smell=_h.ml) : $(MODDIRZ)/%_h.ml : $(MODDIR)/%.h + @[ -d $(dir $@) ] || mkdir -p $(dir $@) + $(MUTE)src2srcml $< $@ -.SECONDARY: $(@PACKAGE@REVENGS) $(@PACKAGE@PREPROC) +$(@PACKAGE@SML) : $(MODDIRZ)/%.smell : $(MODDIRZ)/%_cxx.ml $(MODDIRZ)/%_h.ml + $(MUTE)echo smelling $@ + $(MUTE)java -classpath $(SMELL_DETECTOR_DIR):$(SMELL_DETECTOR_DIR)/xom-1.1.jar -Xmx500m SmellDetector $^ > $@ + $(MUTE)[ -s $@ ] || touch $@ -PACKREVENG += $(@PACKAGE@PREPROC) +.SECONDARY: $(@PACKAGE@SML:.smell=_cxx.ml) $(@PACKAGE@SML:.smell=_h.ml) # 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)) +@PACKAGE@.par: $(patsubst %,@MODULE@/@PACKAGE@/%,$(filter-out dict.%, $(HDRS) $(SRCS) $(DHDR) $(PKGFILE) $(FSRCS) Makefile Makefile.arch lib@PACKAGE@.pkg PROOF-INF)) @echo "Creating archive" $@ ... - @cd @MODULE@; tar cfzh ../$@ @PACKAGE@ + @cd @MODULE@; (tar cfzh ../$@ @PACKAGE@ 2> /dev/null && echo "package" $@ "created in" $(PWD)/$@) || (tar cfzh /tmp/$@ @PACKAGE@ 2> /dev/null && echo "package" $@ "created in /tmp/"$@) @rm -rf @MODULE@/@PACKAGE@ - @echo "done" @MODULE@/@PACKAGE@/Makefile: @MODULE@/Makefile @echo Copying $< to $@ with transformations @@ -391,17 +375,17 @@ PACKREVENG += $(@PACKAGE@PREPROC) @MODULE@/@PACKAGE@/Makefile.arch: $(ROOTSYS)/test/Makefile.arch @echo Copying $< to $@ @[ -d $(dir $@) ] || mkdir -p $(dir $@) - @cp $^ $@ + @cp -pR $^ $@ @MODULE@/@PACKAGE@/PROOF-INF: @MODULE@/PROOF-INF.@PACKAGE@ @echo Copying $< to $@ @[ -d $(dir $@) ] || mkdir -p $(dir $@) - @cp -r $^ $@ + @cp -pR $^ $@ @MODULE@/@PACKAGE@/%: @MODULE@/% @echo Copying $< to $@ @[ -d $(dir $@) ] || mkdir -p $(dir $@) - @cp $< $@ + @cp -pR $< $@ test-@PACKAGE@.par: @PACKAGE@.par @echo "INFO: The file $< is now tested, in case of an error check in par-tmp/@PACKAGE@."