X-Git-Url: http://git.uio.no/git/?a=blobdiff_plain;f=Makefile;h=3a6233288a32b6387e4e2ec7a1c0e0285ebfb28a;hb=70d9362090177e47de17d2065e7d8c27762c21d6;hp=340db0d5b697e2010968952f393cad9fefadd924;hpb=bdfb95938cbd27406564842ae68d0e31f12e59f4;p=u%2Fmrichter%2FAliRoot.git diff --git a/Makefile b/Makefile index 340db0d5b69..3a6233288a3 100644 --- a/Makefile +++ b/Makefile @@ -11,7 +11,7 @@ else MUTE:=@ endif -CLEAN=$(findstring clean,$(patsubst %clean%,clean,$(MAKECMDGOALS))) +CLEAN=$(findstring clean,$(MAKECMDGOALS)) #------------------------------------------------------------------------------- # IRST coding rule check @@ -23,18 +23,8 @@ export CLASSPATH IRST_INSTALLDIR IRST_CONFIG_DIR CODE_CHECK=java rules.ALICE.ALICERuleChecker REV_ENG=$(IRST_INSTALLDIR)/scripts/revEng.sh -#------------------------------------------------------------------------------- -# Include library definition +SMELL_DETECTOR_DIR=$(IRST_INSTALLDIR)/smell-detector -include build/Makefile.config - -#------------------------------------------------------------------------------- -# Location where to install libraries and binaries and common header files - -LIBPATH := lib/tgt_$(ALICE_TARGET) -BINPATH := bin/tgt_$(ALICE_TARGET) -EXPORTDIR := $(ALICE_ROOT)/include -BINLIBDIRS := -L$(ALICE_ROOT)/$(LIBPATH) #------------------------------------------------------------------------------- # Include machine dependent macros @@ -47,8 +37,8 @@ BINLIBDIRS := -L$(ALICE_ROOT)/$(LIBPATH) ifeq ($(ALIDEBUG),YES) override ALICE_TARGET := $(ALICE_TARGET)DEBUG FFLAGS := -g $(filter-out -O%,$(FFLAGS)) -CXXFLAGS := -g $(filter-out -O%,$(CXXLAGS)) -CFLAGS := -g $(filter-out -O%,$(CLAGS)) +CXXFLAGS := -g $(filter-out -O%,$(CXXFLAGS)) +CFLAGS := -g $(filter-out -O%,$(CFLAGS)) SOFLAGS := -g $(filter-out -O%,$(SOFLAGS)) LDFLAGS := -g $(filter-out -O%,$(LDFLAGS)) endif @@ -70,35 +60,86 @@ endif ifdef DATE_ROOT DATEFLAGS = -DALI_DATE -D${DATE_SYS} -DDATE_SYS=${DATE_SYS} -Dlong32=${DATE_LONG32} \ - -Dlong64=${DATE_LONG64} -DdatePointer=${DATE_POINTER} + -Dlong64='${DATE_LONG64}' -DdatePointer=${DATE_POINTER} -I${DATE_COMMON_DEFS} -I${DATE_MONITOR_DIR} +CXXFLAGS += $(DATEFLAGS) +CFLAGS += $(DATEFLAGS) +CINTFLAGS += $(DATEFLAGS) +DEPINC += $(DATEFLAGS) +else +DATEFLAGS = -D`uname` -DDATE_SYS=`uname` -Dlong32='int' \ + -Dlong64='long long' -DdatePointer='long' CXXFLAGS += $(DATEFLAGS) CFLAGS += $(DATEFLAGS) CINTFLAGS += $(DATEFLAGS) DEPINC += $(DATEFLAGS) endif +#------------------------------------------------------------------------------- +# Location where to install libraries and binaries and common header files + +LIBPATH := lib/tgt_$(ALICE_TARGET) +BINPATH := bin/tgt_$(ALICE_TARGET) +EXPORTDIR := $(ALICE_ROOT)/include +BINLIBDIRS := -L$(ALICE_ROOT)/$(LIBPATH) + #------------------------------------------------------------------------------- # Modules to build -ifdef ALIVERBOSE +ifeq (ALIVERBOSE,2) $(warning MAKECMDGOALS=$(MAKECMDGOALS)) endif ALIROOTMODULES := STEER PHOS TRD TPC ZDC MUON PMD FMD TOF ITS \ - CRT RICH START STRUCT EVGEN RALICE ALIFAST VZERO \ - THijing CONTAINERS MEVSIM TMEVSIM THbtp HBTP EMCAL HBTAN \ - THerwig TEPEMGEN EPEMGEN FASTSIM TPHIC RAW MONITOR DISPLAY ANALYSIS \ - JETAN HLT + ACORDE HMPID T0 BCM STRUCT EVGEN RALICE VZERO \ + THijing MEVSIM TMEVSIM THbtp HBTP EMCAL HBTAN \ + THerwig TEPEMGEN EPEMGEN FASTSIM TPHIC RAW MONITOR ANALYSIS \ + JETAN HLT LHC ESDCheck STAT TTherminator CORRFW + +ifneq ($(wildcard $(ROOTSYS)/include/TGLIncludes.h),) +ALIROOTMODULES += EVE +endif ifeq ($(findstring TFluka,$(MAKECMDGOALS)),TFluka) ALIROOTMODULES += TFluka endif +ifeq ($(findstring THydjet,$(MAKECMDGOALS)),THydjet) +ALIROOTMODULES += THydjet +endif + +ifeq ($(findstring PWG0,$(MAKECMDGOALS)),PWG0) +ALIROOTMODULES += PWG0 +endif + +ifeq ($(findstring PWG1,$(MAKECMDGOALS)),PWG1) +ALIROOTMODULES += PWG1 +endif + +ifeq ($(findstring PWG2,$(MAKECMDGOALS)),PWG2) +ALIROOTMODULES += PWG2 +endif + +ifeq ($(findstring PWG3,$(MAKECMDGOALS)),PWG3) +ALIROOTMODULES += PWG3 +endif + +ifeq ($(findstring PWG4,$(MAKECMDGOALS)),PWG4) +ALIROOTMODULES += PWG4 +endif + +ifeq ($(findstring SHUTTLE,$(MAKECMDGOALS)),SHUTTLE) +ALIROOTMODULES += SHUTTLE +endif + ifeq ($(findstring Flugg,$(MAKECMDGOALS)),Flugg) ALIROOTMODULES += Flugg endif -CERNMODULES := PDF PYTHIA6 HIJING MICROCERN HERWIG +CERNMODULES := LHAPDF HIJING MICROCERN HERWIG + +ifneq ($(wildcard $(ROOTSYS)/include/TPythia6.h),) +CERNMODULES += PYTHIA6 +endif MODULES := $(ALIROOTMODULES) $(CERNMODULES) ALIROOT @@ -117,14 +158,42 @@ DEPINC += $(GENINC) #------------------------------------------------------------------------------- # Libraries to link binaries against # Libraries will be linked against SHLIB +# ROOT libraries -LIBS := $(GLIBS) $(ROOTLIBS) $(SYSLIBS) +ROOTCLIBS := $(shell root-config --glibs) -lThread -lMinuit -lHtml -lVMC -lEG -lGeom -lTreePlayer -lXMLIO -lProof -lProofPlayer -lMLP \ + -lSpectrum + +ROOTPLIBS := -lEGPythia6 + +ALILIBS := -L$(LIBDIR) -lMUON -lTPC -lPMD -lTRD -lFMD -lTOF \ + -lITS -lPHOS -lACORDE -lHMPID -lVZERO -lZDC -lSTRUCT \ + -lT0 -lEVGEN -lSTEER + +LIBS := $(ROOTCLIBS) $(ROOTPLIBS) $(SYSLIBS) + +ARVERSIONFILE := $(EXPORTDIR)/ARVersion.h +SVNREV := $(strip $(shell svn info | grep "Last Changed Rev:" | cut -d: -f2 )) +SVNBRANCH := $(subst //alisoft.cern.ch/AliRoot/,,$(shell svn info | grep "URL:" | cut -d: -f3 )) #------------------------------------------------------------------------------- # default target -default: aliroot +default: $(ARVERSIONFILE) + $(MUTE)$(MAKE) aliroot + +FORCE: +#------------------------------------------------------------------------------- +# Write header file with aliroot svn version and url + +$(ARVERSIONFILE): FORCE $(EXPORTDIR) + $(MUTE)rm -f $(ARVERSIONFILE) + @echo "***** Making $(ARVERSIONFILE) *****" + @echo "#ifndef ALIROOT_ARVersion" >> $@ + @echo "#define ALIROOT_ARVersion" >> $@ + @echo "#define ALIROOT_SVN_REVISION $(SVNREV)" >> $@ + @echo "#define ALIROOT_SVN_BRANCH \"$(SVNBRANCH)\"" >> $@ + @echo "#endif" >> $@ #------------------------------------------------------------------------------- # Each module will add to these macros @@ -135,14 +204,16 @@ BINLIBS := EXPORTFILES := #------------------------------------------------------------------------------- -# Dependencies of module.mk files +# Dependencies of module.mk files if not cleaning +ifeq ($(CLEAN),) include build/module.dep +endif #------------------------------------------------------------------------------- # Check if module.mk is present for the library -%.mk: build/module.tpl +%.mk: build/module.tpl build/header.tpl build/clean.tpl share/alibtool ifndef ALIQUIET @echo "***** Creating $@ file *****"; endif @@ -169,7 +240,7 @@ ifeq ($(CLEAN),) ifneq ($(MAKECMDGOALS),depend) ifneq ($(MAKECMDGOALS),) -ifdef ALIVERBOSE +ifeq (ALIVERBOSE,2) $(warning INCLUDEFILES=$(INCLUDEFILES)) endif -include $(INCLUDEFILES) @@ -199,7 +270,93 @@ else alilibs: $(LIBPATH) modules $(ALLLIBS) endif -aliroot: $(BINPATH) $(ALLEXECS) alilibs +aliroot: alilibs $(BINPATH) $(ALLEXECS) + +ROOTALIBDIR=$(shell root-config --libdir) + +ALIMDCSPECFILE=$(RAWDIRO)/alimdc.spec +ALIMDCVERSION=$(subst -,.,$(notdir $(subst /RAW/mdc.h,,$(shell svn info RAW/mdc.h | grep "URL:" | cut -d: -f3 )))) +ALIMDCRELEASE=$(firstword $(shell svn info RAW/mdc.h | grep "Revision:" | cut -d: -f2 )) + +alimdc-rpm: alimdc-static alimdc-specfile + $(MUTE)rm -rf alimdc-root + $(MUTE)mkdir -p alimdc-root/opt/alimdc/lib + $(MUTE)mkdir -p alimdc-root/opt/alimdc/include + $(MUTE)cp RAW/mdc.h alimdc-root/opt/alimdc/include + $(MUTE)cp $(LIBPATH)/libAliMDC.a \ + $(ROOTALIBDIR)/libRoot.a \ + $(ROOTALIBDIR)/libfreetype.a $(ROOTALIBDIR)/libpcre.a \ + alimdc-root/opt/alimdc/lib + $(MUTE)rm -rf RPMS + $(MUTE)mkdir -p RPMS/i386 + $(MUTE)rpmbuild --verbose --define "_topdir $(ALICE_ROOT)" --define "_tmppath $(ALICE_ROOT)" -bb $(ALIMDCSPECFILE) + $(MUTE)cp -p RPMS/i386/alimdc-*.rpm . + $(MUTE)rm -rf alimdc-root + $(MUTE)rm -rf RPMS + @echo "***** alimdc RPM created and put $(ALICE_ROOT) folder *****" + +alimdc-specfile: $(RAWDIRO) + $(MUTE)rm -rf $(ALIMDCSPECFILE) + @echo "***** Making alimdc RPM spec-file $(ALIMDCSPECFILE) *****" + @echo "# RPM specfile for alimdc static libs" >> $(ALIMDCSPECFILE) + @echo "# Package contains both ROOT and AliRoot" >> $(ALIMDCSPECFILE) + @echo "# static libs needed by mStreamRecorder" >> $(ALIMDCSPECFILE) + @echo "# in order to ROOT-ify the incoming raw" >> $(ALIMDCSPECFILE) + @echo "# data" >> $(ALIMDCSPECFILE) + @echo "# Example how-to build alimdc RPM:" >> $(ALIMDCSPECFILE) + @echo "# cd $ALICE_ROOT" >> $(ALIMDCSPECFILE) + @echo "# make alimdc-rpm" >> $(ALIMDCSPECFILE) + @echo "" >> $(ALIMDCSPECFILE) + @echo "Summary: AliMDC static libraries" >> $(ALIMDCSPECFILE) + @echo "Name: alimdc" >> $(ALIMDCSPECFILE) + @echo "Version: $(ALIMDCVERSION)" >> $(ALIMDCSPECFILE) + @echo "Release: $(ALIMDCRELEASE)" >> $(ALIMDCSPECFILE) + @echo "# Copyright: CERN Alice Off-line" >> $(ALIMDCSPECFILE) + @echo "License: CERN Alice Off-line" >> $(ALIMDCSPECFILE) + @echo "Vendor: ALICE Core Off-line Group" >> $(ALIMDCSPECFILE) + @echo "URL: http://aliceinfo.cern.ch" >> $(ALIMDCSPECFILE) + @echo "Group: Applications/Alice" >> $(ALIMDCSPECFILE) + @echo "Prefix: /opt/%{name}" >> $(ALIMDCSPECFILE) + @echo "BuildRoot: %{_tmppath}/%{name}-root" >> $(ALIMDCSPECFILE) + @echo "" >> $(ALIMDCSPECFILE) + @echo "# automatic dependencies" >> $(ALIMDCSPECFILE) + @echo "AutoReqProv: yes" >> $(ALIMDCSPECFILE) + @echo "" >> $(ALIMDCSPECFILE) + @echo "# list here required RPM packages for runtime" >> $(ALIMDCSPECFILE) + @echo "Requires: glibc" >> $(ALIMDCSPECFILE) + @echo "" >> $(ALIMDCSPECFILE) + @echo "Provides: alimdc" >> $(ALIMDCSPECFILE) + @echo "" >> $(ALIMDCSPECFILE) + @echo "# description of the package" >> $(ALIMDCSPECFILE) + @echo "%description" >> $(ALIMDCSPECFILE) + @echo "Package contains both ROOT and AliRoot" >> $(ALIMDCSPECFILE) + @echo "static libs needed by mStreamRecorder" >> $(ALIMDCSPECFILE) + @echo "in order to ROOT-ify the incoming raw" >> $(ALIMDCSPECFILE) + @echo "data. The package version correspond to" >> $(ALIMDCSPECFILE) + @echo "the AliRoot one." >> $(ALIMDCSPECFILE) + @echo "" >> $(ALIMDCSPECFILE) + @echo "# list of files to be installed" >> $(ALIMDCSPECFILE) + @echo "%files" >> $(ALIMDCSPECFILE) + @echo "%defattr (-,root,root)" >> $(ALIMDCSPECFILE) + @echo "%{prefix}/lib/libAliMDC.a" >> $(ALIMDCSPECFILE) + @echo "%{prefix}/lib/libRoot.a" >> $(ALIMDCSPECFILE) + @echo "%{prefix}/lib/libpcre.a" >> $(ALIMDCSPECFILE) + @echo "%{prefix}/lib/libfreetype.a" >> $(ALIMDCSPECFILE) + @echo "%{prefix}/include/mdc.h" >> $(ALIMDCSPECFILE) + +alimdc-static: $(LIBPATH) $(BINPATH) $(RAWDatabaseALIB) $(MDCALIB) $(ESDALIB) $(STEERBaseALIB) $(alimdcCXXO) + $(MUTE)rm -rf $(LIBPATH)/libAliMDC.a + $(MUTE)rm -rf junk + mkdir junk && cd junk && ar x ../$(RAWDatabaseALIB) && ar x ../$(MDCALIB) && ar x ../$(ESDALIB) && ar x ../$(STEERBaseALIB) && ar r ../$(LIBPATH)/libAliMDC.a *.o && cd .. && rm -rf junk + $(LD) $(LDFLAGS) -o $(BINPATH)/alimdca $(alimdcCXXO) \ + $(LIBPATH)/libAliMDC.a \ + $(ROOTALIBDIR)/libRoot.a \ + $(ROOTALIBDIR)/libfreetype.a $(ROOTALIBDIR)/libpcre.a \ + -ldl + +alilibs-static: $(LIBPATH) modules $(ALLALIBS) + +include build/MakefileDA #------------------------------------------------------------------------------- # Single Makefile "distribution": Makefile + modules + mkdepend scripts @@ -215,13 +372,13 @@ debug: ifndef ALIQUIET @echo "***** Entering DEBUG mode. *****" endif - @(export ALIDEBUG=YES && $(MAKE)) + @(export ALIDEBUG=YES && $(MAKE) aliroot) profile: ifndef ALIQUIET @echo "***** Entering PROFILE mode. *****" endif - @(export ALIPROFILE=YES && $(MAKE)) + @(export ALIPROFILE=YES && $(MAKE) aliroot) $(MODULES): ifndef ALIQUIET @@ -276,15 +433,19 @@ CHECKMODULES := $(filter-out HBTP,$(CHECKMODULES)) CHECKMODULES := $(filter-out MEVSIM,$(CHECKMODULES)) CHECKMODULES := $(filter-out EPEMGEN,$(CHECKMODULES)) CHECKMODULES := $(filter-out TPHIC,$(CHECKMODULES)) -CHECKMODULES := $(filter-out PDF,$(CHECKMODULES)) +CHECKMODULES := $(filter-out LHAPDF,$(CHECKMODULES)) CHECKMODULES := $(filter-out MICROCERN,$(CHECKMODULES)) check-all: $(patsubst %,%/module.mk,$(CHECKMODULES)) $(patsubst %,check-%,$(CHECKMODULES)) +smell-all: $(patsubst %,%/module.mk,$(CHECKMODULES)) $(patsubst %,smell-%,$(CHECKMODULES)) + reveng-all: $(patsubst %,%/module.mk,$(CHECKMODULES)) $(patsubst %,reveng-%,$(CHECKMODULES)) revdisp-all: $(patsubst %,%/module.mk,$(CHECKMODULES)) $(patsubst %,revdisp-%,$(CHECKMODULES)) +smell-all: $(patsubst %,%/module.mk,$(CHECKMODULES)) $(patsubst %,smell-%,$(CHECKMODULES)) + clean-dicts: ifndef ALIQUIET @echo "***** Cleaning up G__ files *****" @@ -323,6 +484,8 @@ endif clean-check-all: $(patsubst %,%/module.mk,$(CHECKMODULES)) $(patsubst %,clean-check-%,$(CHECKMODULES)) +clean-smell-all: $(patsubst %,%/module.mk,$(CHECKMODULES)) $(patsubst %,clean-smell-%,$(CHECKMODULES)) + clean-reveng-all: $(patsubst %,%/module.mk,$(CHECKMODULES)) $(patsubst %,clean-reveng-%,$(CHECKMODULES)) htmldoc: