+#-*- Mode: Makefile -*-
ifndef PACKFFLAGS
endif
ifndef PACKDCXXFLAGS
-ifeq ($(PLATFORM),linuxicc)
-@PACKAGE@DCXXFLAGS:=$(filter-out -O%,$(CXXFLAGS)) -O0
+@PACKAGE@DCXXFLAGS:=$(CXXFLAGSNO)
else
-@PACKAGE@DCXXFLAGS:=$(filter-out -O%,$(CXXFLAGS))
-endif
-else
-@PACKAGE@DCXXFLAGS:=$(PACKCXXFLAGS)
+@PACKAGE@DCXXFLAGS:=$(PACKDCXXFLAGS)
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
@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
@PACKAGE@LIB := $(@PACKAGE@LIB)
endif
-# include all dependency files
+# include all dependence files
INCLUDEFILES +=$(@PACKAGE@DEP)
EXPORTFILES += $(@PACKAGE@EXPORTDEST)
ifndef ALIQUIET
@echo "***** Copying file $^ to $@ *****"
endif
- @[ -d $(dir $@) ] || mkdir $(dir $@)
+ @[ -d $(dir $@) ] || mkdir -p $(dir $@)
@cp $^ $@
endif
@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)/$@ ;\
- rm -rf $$TMPDIR
+ cd $(ALICE_ROOT) ; \rm -rf $$TMPDIR
ifneq ($(DYEXT),)
$(@PACKAGE@DLIB):$(@PACKAGE@O) $(@PACKAGE@DO) @MODULE@/module.mk
@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)/$@ ;\
$(DYLD) $(@PACKAGE@DYFLAGS) -o $(CURDIR)/$@ $(notdir $(@PACKAGE@O) $(@PACKAGE@DO)) $(@PACKAGE@ELIBSDIR) $(@PACKAGE@ELIBS) $(DYLIB);\
chmod a-w $(CURDIR)/$@ ;\
- rm -rf $$TMPDIR
+ cd $(ALICE_ROOT) ; \rm -rf $$TMPDIR
endif
#------------------------------------------------------------------------
@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 $@
@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)
$(@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)
#Different targets for the module
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
ifndef ALIQUIET
@echo "***** Compiling $< *****";
$(@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
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
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
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
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)))
-check-@PACKAGE@: $(@PACKAGE@CHECKS)
+@PACKAGE@CHECKS := $(patsubst %.cxx,@MODULE@/check/%.viol,$(SRCS))
+
+check-@MODULE@: $(@PACKAGE@CHECKS)
# IRST coding rule check
-@PACKAGE@/check/%.i : @PACKAGE@/%.cxx
+@MODULE@/check/%.i : @MODULE@/%.cxx @MODULE@/%.h
@[ -d $(dir $@) ] || mkdir -p $(dir $@)
$(MUTE)$(CXX) -E $(@PACKAGE@DEFINE) $(@PACKAGE@INC) $< > $@ $(@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/$(SUBDIR)/%.viol : @MODULE@/check/$(SUBDIR)/%.i
+ @cd @MODULE@ ; [ -r @MODULE@ ] || ln -s ../@MODULE@ @MODULE@
+ $(MUTE)echo $@ ; $(CODE_CHECK) $< ./@MODULE@/$(@PACKAGE@SDIR) > $@
+
+# IRST coding rule check
+@MODULE@/check/%.viol : @MODULE@/check/%.i
+ @cd @MODULE@ ; [ -r @MODULE@ ] || ln -s ../@MODULE@ @MODULE@
+ $(MUTE)echo $@ ; $(CODE_CHECK) $< ./@MODULE@ > $@
@PACKAGE@PREPROC = $(patsubst %.viol,%.i,$(@PACKAGE@CHECKS))