]> git.uio.no Git - u/mrichter/AliRoot.git/blobdiff - build/module.tpl
Protection against deletion of Header.
[u/mrichter/AliRoot.git] / build / module.tpl
index 7c932acff11b43e6c4d2230495826179190b45fc..c5b00379c925fe1dc2938436116fe885c73edb64 100644 (file)
@@ -51,11 +51,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 +67,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 +95,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))
@@ -249,6 +261,20 @@ else
          $(MUTE)$(LD) $(@PACKAGE@LDFLAGS) $(@PACKAGE@O) $(@PACKAGE@DO) $(BINLIBDIRS) $(@PACKAGE@ELIBSDIR) $(@PACKAGE@ELIBS) $(@PACKAGE@BLIBS) $(EXEFLAGS) -o $@
 endif
 
+$(@PACKAGE@DAL): $(@PACKAGE@CINTHDRS) @MODULE@/module.mk @MODULE@/tgt_$(ALICE_TARGET)/@PACKAGE@_srcslist
+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' >> $@
+
 $(@PACKAGE@DS): $(@PACKAGE@CINTHDRS) $(@PACKAGE@DH) @MODULE@/module.mk @MODULE@/tgt_$(ALICE_TARGET)/@PACKAGE@_srcslist
 ifndef ALIQUIET
         @echo "***** Creating $@ *****";
@@ -355,11 +381,14 @@ endif
 .PRECIOUS: $(patsubst %.F,$(MODDIRO)/%.d,$(patsubst %.f,$(MODDIRO)/%.d,$(FSRCS)))
 
 @PACKAGE@CHECKS := $(patsubst %.cxx,@MODULE@/check/%.viol,$(SRCS))
+@PACKAGE@SRCDIR := $(dir $(word 1,$(patsubst %.cxx,@MODULE@/%.cxx,$(SRCS))))
+@PACKAGE@CHKDIR := $(dir $(word 1,$(@PACKAGE@CHECKS)))
+@PACKAGE@OBJDIR := $(dir $(word 1,$(patsubst %.cxx,@MODULE@/tgt_$(ALICE_TARGET)/%.cxx,$(SRCS))))
 
 check-@MODULE@: $(@PACKAGE@CHECKS)
 
 # IRST coding rule check 
-@MODULE@/check/%.i : @MODULE@/%.cxx @MODULE@/tgt_$(ALICE_TARGET)/%.d
+$(@PACKAGE@CHKDIR)%.i : $(@PACKAGE@SRCDIR)%.cxx $(@PACKAGE@OBJDIR)%.d
        @[ -d $(dir $@) ] || mkdir -p $(dir $@)
        $(MUTE)$(CXX) -E $(@PACKAGE@DEFINE) $(@PACKAGE@INC) -I. $< > $@ $(@PACKAGE@CXXFLAGS)
        @cd $(dir $@) ; $(IRST_INSTALLDIR)/patch/patch4alice.prl $(notdir $@)
@@ -376,12 +405,33 @@ check-@MODULE@: $(@PACKAGE@CHECKS)
 
 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@
+       @cd @MODULE@; tar cfzh /tmp/$@ @PACKAGE@
        @rm -rf @MODULE@/@PACKAGE@
-       @echo "done"
+       @echo "package" $@ "in /tmp/"$@
+       @echo $@ "done"
 
 @MODULE@/@PACKAGE@/Makefile: @MODULE@/Makefile
        @echo Copying $< to $@ with transformations
@@ -391,21 +441,21 @@ 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@."
        @mkdir -p par-tmp
-       @cd par-tmp; tar xfz ../$<;     cd $(subst .par,,$<); PROOF-INF/BUILD.sh
+       @cd par-tmp; tar xfz /tmp/$<;   cd $(subst .par,,$<); PROOF-INF/BUILD.sh
        @rm -rf par-tmp/@PACKAGE@
        @echo "INFO: Testing succeeded (already cleaned up)"