#---------------------------------------------------------------------------- # Setup the project cmake_minimum_required(VERSION 2.6 FATAL_ERROR) project(TheExample) #---------------------------------------------------------------------------- # Find Geant4 package, activating all available UI and Vis drivers by default # You can set WITH_GEANT4_UIVIS to OFF via the command line or ccmake/cmake-gui # to build a batch mode only executable # option(WITH_GEANT4_UIVIS "Build example with Geant4 UI and Vis drivers" ON) if(WITH_GEANT4_UIVIS) find_package(Geant4 REQUIRED ui_all vis_all) else() find_package(Geant4 REQUIRED) endif() #---------------------------------------------------------------------------- # Setup Geant4 include directories and compile definitions # Setup include directory for this project # include(${Geant4_USE_FILE}) #---------------------------------------------------------------------------- #Setup CRY----------------------------------- find_library( CRY NAMES CRY PATHS $ENV{CRYHOME}/lib NO_DEFAULT_PATH ) set(CRY_INCLUDE_DIRS $ENV{CRYHOME}/src) MESSAGE ("Cry setup: " ${CRY_INCLUDE_DIRS} ) #set(CRY_LIBRARY_DIR ${CRYHOME}/lib) set(CRY_LIBRARIES $ENV{CRYHOME}/lib/libCRY.a) #----------------------------------------------- #set (CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -std=c++11") # Locate sources and headers for this project # NB: headers are included so they will show up in IDEs # include_directories(${CMAKE_CURRENT_SOURCE_DIR}/include ${Geant4_INCLUDE_DIR} ${CRY_INCLUDE_DIRS} ) file(GLOB sources ${PROJECT_SOURCE_DIR}/src/*.cc) file(GLOB headers ${PROJECT_SOURCE_DIR}/include/*.hh) #---------------------------------------------------------------------------- # Add the executable, and link it to the Geant4 libraries # add_executable(TheExample TheExample.cc ${sources} ${headers}) target_link_libraries(TheExample ${Geant4_LIBRARIES} ${CRY_LIBRARIES}) #---------------------------------------------------------------------------- # Copy all scripts to the build directory, i.e. the directory in which we # build B5. This is so that we can run the executable directly because it # relies on these scripts being in the current working directory. # set(_SCRIPTS init.mac init_vis.mac run1.mac vis.mac setupCry.file ) foreach(_script ${_SCRIPTS}) configure_file( ${PROJECT_SOURCE_DIR}/${_script} ${PROJECT_BINARY_DIR}/${_script} COPYONLY ) endforeach() #---------------------------------------------------------------------------- # Add program to the project targets # (this avoids the need of typing the program name after make) # add_custom_target(Tutorial DEPENDS TheExample) #---------------------------------------------------------------------------- # Install the executable to 'bin' directory under CMAKE_INSTALL_PREFIX # install(TARGETS TheExample DESTINATION bin) install(FILES ${_SCRIPTS} DESTINATION share/TheExample)