]> git.uio.no Git - u/mrichter/AliRoot.git/blobdiff - build/module.tpl
Draw charged tracks as straight lines when magnetic field is near zero.
[u/mrichter/AliRoot.git] / build / module.tpl
index b59cff4ab113b4152d79c38cf68a192339b8e066..a3177caebaf545c0eaea19efc72a92b9406c31c1 100644 (file)
@@ -85,16 +85,13 @@ endif
 @PACKAGE@S:=$(patsubst %,$(MODDIR)/%,$(SRCS))
 @PACKAGE@H:=$(patsubst %,$(MODDIR)/%,$(HDRS)) $(EHDRS)
 
-#c++ source subdirectories
-@PACKAGE@SDIR:=$(SUBDIR)
-
 #############################################################################
 #
 #            If special rootcint headerfiles is specified use them
 #                         else use all headers
 
 ifndef CINTHDRS
-@PACKAGE@CINTHDRS:=$(@PACKAGE@H) 
+@PACKAGE@CINTHDRS:=$(@PACKAGE@H)
 else
 @PACKAGE@CINTHDRS:=$(CINTHDRS)
 endif
@@ -104,10 +101,12 @@ endif
 @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)
 
 
 
@@ -252,25 +251,27 @@ endif
 
 $(@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;)
         @\rm -f $(patsubst %.cxx,%.d, $@)
-        $(MUTE)rootcint -f $@ -c $(@PACKAGE@DEFINE) $(CINTFLAGS) $(@PACKAGE@INC) $(@PACKAGE@CINTHDRS) $(@PACKAGE@DH) 
+        $(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) $(@PACKAGE@DEFINE) -c $(@PACKAGE@INC)  -I$(ALICE_ROOT) $< -o $@ $(@PACKAGE@DCXXFLAGS)
 
-$(MODDIRO)/@PACKAGE@_srcslist: FORCE
-       @for i in $(@PACKAGE@CS) $(@PACKAGE@S); do echo $$i; done | sort > $@.new ;\
-       diff $@ $@.new 2>/dev/null | sed -n -e "s?^\< *@MODULE@?@MODULE@/tgt_$(ALICE_TARGET)?p" | \
-       sed -e "s?\.c.*\$$?.\*?" | xargs \rm -f ;\
-       diff -q -w >/dev/null 2>&1 $@ $@.new ;\
-       if [ $$? -ne 0 ]; then \mv $@.new $@; echo "***** Source changed, remaking $(@PACKAGE@DS) *****";\
-       else \rm $@.new; fi
+$(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 '/^\</{sub(".c.*",".",$$2); print $$2}' | $(XARGS) basename` ;\
+       do grep -l $$j `find */tgt_$(ALICE_TARGET) -name "*.d"` | $(XARGS) echo \rm -f ;\
+       (find @MODULE@/tgt_$(ALICE_TARGET) -name "$${j}d" ; find @MODULE@/tgt_$(ALICE_TARGET) -name "$${j}o") | $(XARGS) echo \rm -f ;\
+       done
+       $(MUTE)diff -q -w >/dev/null 2>&1 $@ $@.new ;\
+       if [ $$? -ne 0 ]; then \mv $@.new $@; else \rm $@.new; fi
 
 #Different targets for the module
 
@@ -286,28 +287,28 @@ endif
 depend-@PACKAGE@: $(@PACKAGE@DEP)
 
 # determination of object files
-$(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
@@ -321,25 +322,28 @@ 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 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 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 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 dependences for $< *****";
 endif
@@ -355,18 +359,14 @@ endif
 check-@MODULE@: $(@PACKAGE@CHECKS)
 
 # IRST coding rule check 
-@MODULE@/check/%.i : @MODULE@/%.cxx @MODULE@/%.h
+@MODULE@/check/%.i : @MODULE@/%.cxx @MODULE@/tgt_$(ALICE_TARGET)/%.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/$(SUBDIR)/%.viol : @MODULE@/check/$(SUBDIR)/%.i
-       $(MUTE)echo $@ ; $(CODE_CHECK) $< ./@MODULE@/$(@PACKAGE@SDIR) > $@
-
 # IRST coding rule check
 @MODULE@/check/%.viol : @MODULE@/check/%.i
-       $(MUTE)echo $@ ; $(CODE_CHECK) $< ./@MODULE@ > $@
+       $(MUTE)echo $@ ; $(CODE_CHECK) $< $(shell echo $(dir $<) | sed -e 's:/check::') > $@
 
 @PACKAGE@PREPROC       = $(patsubst %.viol,%.i,$(@PACKAGE@CHECKS))
 
@@ -374,15 +374,65 @@ check-@MODULE@: $(@PACKAGE@CHECKS)
 
 .SECONDARY: $(@PACKAGE@REVENGS) $(@PACKAGE@PREPROC)
 
-reveng-@PACKAGE@:              @PACKAGE@/check/classDiagram.dot
+PACKREVENG += $(@PACKAGE@PREPROC)
 
-@PACKAGE@/check/classDiagram.dot:      $(@PACKAGE@PREPROC)
-       @$(REV_ENG) $^
-       @-mv classDiagram.dot $@
+# IRST code smell checker
 
-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
+@PACKAGE@SMELL := $(patsubst %.cxx,@MODULE@/smell/%.smell,$(SRCS))
 
+smell-@MODULE@: $(@PACKAGE@SMELL)
+
+@MODULE@/smell/%.occ : @MODULE@/%.cxx 
+       $(MUTE)echo smelling $@
+       @[ -d $(dir $@) ] || mkdir -p $(dir $@)
+       @$(CXX) -E $(@PACKAGE@DEFINE) -D__opencxx $(@PACKAGE@INC) $(@PACKAGE@CXXFLAGS) $< -o $@ -x c++ $<
+
+@MODULE@/smell/%.smell : @MODULE@/smell/%.occ
+       @$(SMELL_DETECTOR_DIR)/patch-smell-detector.prl $<
+       @java -classpath $(SMELL_DETECTOR_DIR) Stripper $<
+       @$(SMELL_DETECTOR_DIR)/code-smell1 -n -E -c $(patsubst %.occ, %.i, $<) -Mclass=$(patsubst $(dir $@)%.occ,%, $<) > $(patsubst %.occ,%.smell, $<)
+       @$(SMELL_DETECTOR_DIR)/code-smell2 -n -E -c $(patsubst %.occ, %.i, $<) -Mclass=$(patsubst $(dir $@)%.occ,%, $<) >> $(patsubst %.occ,%.smell, $<)
+       @$(SMELL_DETECTOR_DIR)/code-smell3 -n -E -c $(patsubst %.occ, %.i, $<) -Mclass=$(patsubst $(dir $@)%.occ,%, $<) >> $(patsubst %.occ,%.smell, $<)
+       @$(SMELL_DETECTOR_DIR)/code-smell4 -n -E -c $(patsubst %.occ, %.i, $<) -Mclass=$(patsubst $(dir $@)%.occ,%, $<) >> $(patsubst %.occ,%.smell, $<)
+       @$(SMELL_DETECTOR_DIR)/code-smell5 -n -E -c $(patsubst %.occ, %.i, $<) -Mclass=$(patsubst $(dir $@)%.occ,%, $<) >> $(patsubst %.occ,%.smell, $<)
+       @$(SMELL_DETECTOR_DIR)/code-smell6 -n -E -c $(patsubst %.occ, %.i, $<) -Mclass=$(patsubst $(dir $@)%.occ,%, $<) >> $(patsubst %.occ,%.smell, $<)
+       @$(SMELL_DETECTOR_DIR)/code-smell7 -n -E -c $(patsubst %.occ, %.i, $<) -Mclass=$(patsubst $(dir $@)%.occ,%, $<) >> $(patsubst %.occ,%.smell, $<)
+       @$(SMELL_DETECTOR_DIR)/code-smell8 -n -E -c $(patsubst %.occ, %.i, $<) -Mclass=$(patsubst $(dir $@)%.occ,%, $<) >> $(patsubst %.occ,%.smell, $<)
+       @$(SMELL_DETECTOR_DIR)/code-smell9 -n -E -c $(patsubst %.occ, %.i, $<) -Mclass=$(patsubst $(dir $@)%.occ,%, $<) >> $(patsubst %.occ,%.smell, $<)
+       @$(SMELL_DETECTOR_DIR)/code-smell10 -n -E -c $(patsubst %.occ, %.i, $<) -Mclass=$(patsubst $(dir $@)%.occ,%, $<) >> $(patsubst %.occ,%.smell, $<)
+       @mv $(patsubst $(dir $@)%.occ,%.ii, $<) $(dir $@)
+
+
+# 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"
+
+@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@/' < $^ > $@
+
+@MODULE@/@PACKAGE@/Makefile.arch: $(ROOTSYS)/test/Makefile.arch
+       @echo Copying $< to $@
+       @[ -d $(dir $@) ] || mkdir -p $(dir $@)
+       @cp $^ $@
+
+@MODULE@/@PACKAGE@/PROOF-INF: @MODULE@/PROOF-INF.@PACKAGE@
+       @echo Copying $< to $@
+       @[ -d $(dir $@) ] || mkdir -p $(dir $@)
+       @cp -r $^ $@
+
+@MODULE@/@PACKAGE@/%: @MODULE@/%
+       @echo Copying $< to $@
+       @[ -d $(dir $@) ] || mkdir -p $(dir $@)
+       @cp $< $@
+
+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)"