82 lines
2.6 KiB
CMake
82 lines
2.6 KiB
CMake
# $Id: CMakeLists.txt 86065 2014-11-07 08:51:15Z gcosmo $
|
|
|
|
#----------------------------------------------------------------------------
|
|
# Setup the project
|
|
cmake_minimum_required(VERSION 2.6 FATAL_ERROR)
|
|
project(scifiSim)
|
|
|
|
#----------------------------------------------------------------------------
|
|
# 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})
|
|
include_directories(${PROJECT_SOURCE_DIR}/include)
|
|
|
|
#include("FindROOT.cmake")
|
|
set(CMAKE_MODULE_PATH$ENV{ROOTSYS}/etc/cmake)
|
|
find_package(ROOT REQUIRED)
|
|
list(APPEND libs $ENV{ROOTSYS}/lib)
|
|
include_directories($ENV{ROOTSYS}/include)
|
|
message(status $ENV{ROOTSYS}/include)
|
|
|
|
|
|
#----------------------------------------------------------------------------
|
|
# Locate sources and headers for this project
|
|
# NB: headers are included so they will show up in IDEs
|
|
#
|
|
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(scifiSim scifiSim.cc ${sources} ${headers})
|
|
target_link_libraries(scifiSim ${Geant4_LIBRARIES} ${ROOT_LIBRARIES})
|
|
|
|
#----------------------------------------------------------------------------
|
|
# Copy all scripts to the build directory, i.e. the directory in which we
|
|
# build B1. This is so that we can run the executable directly because it
|
|
# relies on these scripts being in the current working directory.
|
|
#
|
|
set(EXAMPLEB1_SCRIPTS
|
|
# exampleB1.in
|
|
# exampleB1.out
|
|
# init_vis.mac
|
|
# run1.mac
|
|
# run2.mac
|
|
# vis.mac
|
|
)
|
|
|
|
foreach(_script ${EXAMPLEB1_SCRIPTS})
|
|
configure_file(
|
|
${PROJECT_SOURCE_DIR}/${_script}
|
|
${PROJECT_BINARY_DIR}/${_script}
|
|
COPYONLY
|
|
)
|
|
endforeach()
|
|
|
|
#----------------------------------------------------------------------------
|
|
# For internal Geant4 use - but has no effect if you build this
|
|
# example standalone
|
|
#
|
|
add_custom_target(DEPENDS)
|
|
|
|
#----------------------------------------------------------------------------
|
|
# Install the executable to 'bin' directory under CMAKE_INSTALL_PREFIX
|
|
#
|
|
install(TARGETS DESTINATION bin)
|
|
|
|
|