]> git.uio.no Git - u/mrichter/AliRoot.git/blobdiff - EVGEN/CMakeLists.txt
Update timestamps for new AMANDA simulation (17/02/2015)
[u/mrichter/AliRoot.git] / EVGEN / CMakeLists.txt
index e6f1fe775daa49774f89f5ae923304b84c101893..80cbe5b298b94ccaa15f0f91fd5d7dc81b575ea3 100644 (file)
-# -*- mode: cmake -*-
+# **************************************************************************
+# * Copyright(c) 1998-2014, ALICE Experiment at CERN, All rights reserved. *
+# *                                                                        *
+# * Author: The ALICE Off-line Project.                                    *
+# * Contributors are mentioned in the code where appropriate.              *
+# *                                                                        *
+# * Permission to use, copy, modify and distribute this software and its   *
+# * documentation strictly for non-commercial purposes is hereby granted   *
+# * without fee, provided that the above copyright notice appears in all   *
+# * copies and that both the copyright notice and this permission notice   *
+# * appear in the supporting documentation. The authors make no claims     *
+# * about the suitability of this software for any purpose. It is          *
+# * provided "as is" without express or implied warranty.                  *
+# **************************************************************************
 
-# Create a library called "lib<name>" which includes the source files given in
-# the array .
-# The extension is already found.  Any number of sources could be listed here.
+# Module
+set(MODULE EVGEN)
 
-set(INCLUDE_DIRECTORIES
-${CMAKE_SOURCE_DIR}/EVGEN
-${CMAKE_SOURCE_DIR}/STEER 
-${CMAKE_SOURCE_DIR}/FASTSIM
-${ROOT_INCLUDE_DIR}
+# Module include folder
+include_directories(${AliRoot_SOURCE_DIR}/${MODULE})
+
+# Additional include folders in alphabetical order except ROOT
+include_directories(${ROOT_INCLUDE_DIR}
+                    ${AliRoot_SOURCE_DIR}/FASTSIM
+                    ${AliRoot_SOURCE_DIR}/LHAPDF
+                    ${AliRoot_SOURCE_DIR}/STEER/ESD
+                    ${AliRoot_SOURCE_DIR}/STEER/STEER
+                    ${AliRoot_SOURCE_DIR}/STEER/STEERBase
+                    ${AliRoot_SOURCE_DIR}/TEvtGen
+                    ${AliRoot_SOURCE_DIR}/TEvtGen/THepMCParser
+                   )
+
+# Sources
+set(SRCS
+    AliDecayerExodus.cxx
+    AliDecayerPolarized.cxx
+    AliDimuCombinator.cxx
+    AliGenAfterBurnerFlow.cxx
+    AliGenBeamGas.cxx
+    AliGenBox.cxx
+    AliGenCocktailAfterBurner.cxx
+    AliGenCocktail.cxx
+    AliGenCocktailEntry.cxx
+    AliGenCorrHF.cxx
+    AliGenCosmicsParam.cxx
+    AliGenDeuteron.cxx
+    AliGenDoubleScan.cxx
+    AliGenEMCocktail.cxx
+    AliGenEMlib.cxx
+    AliGenExtFile.cxx
+    AliGenFixed.cxx
+    AliGenFunction.cxx
+    AliGenGeVSim.cxx
+    AliGenGSIlib.cxx
+    AliGenHalo.cxx
+    AliGenHaloProtvino.cxx
+    AliGenHBTosl.cxx
+    AliGenHIJINGparaBa.cxx
+    AliGenHIJINGpara.cxx
+    AliGenHMPIDlib.cxx
+    AliGenITSULib.cxx
+    AliGenKrypton.cxx
+    AliGenLcLib.cxx
+    AliGenLib.cxx
+    AliGenLightNuclei.cxx
+    AliGenMC.cxx
+    AliGenMUONCocktail.cxx
+    AliGenMUONCocktailpp.cxx
+    AliGenMUONlib.cxx
+    AliGenMUONLMR.cxx
+    AliGenPairFlat.cxx
+    AliGenParam.cxx
+    AliGenPHOSlib.cxx
+    AliGenPileup.cxx
+    AliGenPMDlib.cxx
+    AliGenPromptPhotons.cxx
+    AliGenReaderCwn.cxx
+    AliGenReader.cxx
+    AliGenReaderEcalHijing.cxx
+    AliGenReaderEcalJets.cxx
+    AliGenReaderEMD.cxx
+    AliGenReaderHepMC.cxx
+    AliGenReaderSL.cxx
+    AliGenReaderTreeK.cxx
+    AliGenScan.cxx
+    AliGenSlowNucleons.cxx
+    AliGenSTRANGElib.cxx
+    AliGenThermalPhotons.cxx
+    AliGenThetaSlice.cxx
+    AliGenTHnSparse.cxx
+    AliGenTunedOnPbPb.cxx
+    AliGeVSimParticle.cxx
+    AliOmegaDalitz.cxx
+    AliSlowNucleonModel.cxx
+    AliSlowNucleonModelExp.cxx
 )
 
-include_directories( ${INCLUDE_DIRECTORIES})
+# Headers from sources
+string(REPLACE ".cxx" ".h" HDRS "${SRCS}")
+
+# Additional header files
+set(HDRS ${HDRS} AliDecayer.h)
+
+# Generate the dictionary
+# It will create G_ARG1.cxx and G_ARG1.h / ARG1 = function first argument
+get_directory_property(incdirs INCLUDE_DIRECTORIES)
+generate_dictionary("${MODULE}" "${MODULE}LinkDef.h" "${HDRS}" "${incdirs}")
+
+# Generate the ROOT map
+# Dependecies
+set(LIBDEPS STEERBase STEER ESD lhapdf TEvtGen FASTSIM THepMCParser)
+generate_rootmap("${MODULE}" "${LIBDEPS}" "${CMAKE_CURRENT_SOURCE_DIR}/${MODULE}LinkDef.h")
+
+# Add a library to the project using the specified source files
+add_library(${MODULE} SHARED ${SRCS} G__${MODULE}.cxx)
 
-set(LINK_DIRECTORIES
-${ROOT_LIBRARY_DIR}
-) 
+# Additional compilation flags
+set_target_properties(${MODULE} PROPERTIES COMPILE_FLAGS "")
 
-link_directories( ${LINK_DIRECTORIES})
+# Linking the library
+target_link_libraries(${MODULE} ${LIBDEPS})
 
-SetModule()
+# System dependent: Modify the way the library is build
+if(${CMAKE_SYSTEM} MATCHES Darwin)
+    set_target_properties(${MODULE} PROPERTIES LINK_FLAGS "-undefined dynamic_lookup")
+endif(${CMAKE_SYSTEM} MATCHES Darwin)
 
-include(CMake_libEVGEN.txt)
+# Installation
+install(TARGETS ${MODULE}
+  ARCHIVE DESTINATION lib
+  LIBRARY DESTINATION lib)
+install(FILES ${HDRS} DESTINATION include)
 
+message(STATUS "${MODULE} enabled")