forked from alisw/alidist
-
Notifications
You must be signed in to change notification settings - Fork 1
/
fairroot.sh
112 lines (105 loc) · 5.84 KB
/
fairroot.sh
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
package: FairRoot
version: "%(short_hash)s"
tag: "7701b7e6917ae3bf86a1756c8d0497a108734aa8"
source: https://github.com/FairRootGroup/FairRoot
requires:
- generators
- simulation
- ROOT
- boost
- protobuf
- FairLogger
- FairMQ
- yaml-cpp
- "GCC-Toolchain:(?!osx)"
env:
VMCWORKDIR: "$FAIRROOT_ROOT/share/fairbase/examples"
GEOMPATH: "$FAIRROOT_ROOT/share/fairbase/examples/common/geometry"
CONFIG_DIR: "$FAIRROOT_ROOT/share/fairbase/examples/common/gconfig"
prepend_path:
ROOT_INCLUDE_PATH: "$FAIRROOT_ROOT/include"
---
# Making sure people do not have SIMPATH set when they build fairroot.
# Unfortunately SIMPATH seems to be hardcoded in a bunch of places in
# fairroot, so this really should be cleaned up in FairRoot itself for
# maximum safety.
unset SIMPATH
case $ARCHITECTURE in
osx*)
# If we preferred system tools, we need to make sure we can pick them up.
[[ ! $BOOST_ROOT ]] && BOOST_ROOT=`brew --prefix boost`
[[ ! $PROTOBUF_ROOT ]] && PROTOBUF_ROOT=`brew --prefix protobuf`
[[ ! $GSL_ROOT ]] && GSL_ROOT=`brew --prefix gsl`
MACOSX_RPATH=OFF
SONAME=dylib
;;
*) SONAME=so ;;
esac
[[ $BOOST_ROOT ]] && BOOST_NO_SYSTEM_PATHS=ON || BOOST_NO_SYSTEM_PATHS=OFF
cmake $SOURCEDIR \
${CMAKE_GENERATOR:+-G "$CMAKE_GENERATOR"} \
${MACOSX_RPATH:+-DMACOSX_RPATH=${MACOSX_RPATH}} \
-DCMAKE_CXX_FLAGS="$CXXFLAGS" \
${CMAKE_BUILD_TYPE:+-DCMAKE_BUILD_TYPE=$CMAKE_BUILD_TYPE} \
-DROOTSYS=$ROOTSYS \
-DROOT_CONFIG_SEARCHPATH=$ROOT_ROOT/bin \
-DPythia6_LIBRARY_DIR=$PYTHIA6_ROOT/lib \
-DGeant3_DIR=$GEANT3_ROOT \
-DDISABLE_GO=ON \
-DBUILD_EXAMPLES=OFF \
${GEANT4_ROOT:+-DGeant4_DIR=$GEANT4_ROOT} \
-DFAIRROOT_MODULAR_BUILD=ON \
${DDS_ROOT:+-DDDS_PATH=$DDS_ROOT} \
${BOOST_ROOT:+-DBOOST_ROOT=$BOOST_ROOT} \
-DBoost_NO_SYSTEM_PATHS=${BOOST_NO_SYSTEM_PATHS} \
${GSL_ROOT:+-DGSL_DIR=$GSL_ROOT} \
${PROTOBUF_ROOT:+-DProtobuf_LIBRARY=$PROTOBUF_ROOT/lib/libprotobuf.$SONAME} \
${PROTOBUF_ROOT:+-DProtobuf_LITE_LIBRARY=$PROTOBUF_ROOT/lib/libprotobuf-lite.$SONAME} \
${PROTOBUF_ROOT:+-DProtobuf_PROTOC_LIBRARY=$PROTOBUF_ROOT/lib/libprotoc.$SONAME} \
${PROTOBUF_ROOT:+-DProtobuf_INCLUDE_DIR=$PROTOBUF_ROOT/include} \
${PROTOBUF_ROOT:+-DProtobuf_PROTOC_EXECUTABLE=$PROTOBUF_ROOT/bin/protoc} \
${CXXSTD:+-DCMAKE_CXX_STANDARD=$CXXSTD} \
-DCMAKE_EXPORT_COMPILE_COMMANDS=ON \
-DCMAKE_INSTALL_LIBDIR=lib \
-DCMAKE_INSTALL_PREFIX=$INSTALLROOT
cmake --build . -- -j$JOBS install
# Work around hardcoded paths in PCM
for DIR in source sink field event sim steer; do
ln -nfs ../include $INSTALLROOT/include/$DIR
done
# Modulefile
MODULEDIR="$INSTALLROOT/etc/modulefiles"
MODULEFILE="$MODULEDIR/$PKGNAME"
mkdir -p "$MODULEDIR"
cat > "$MODULEFILE" <<EoF
#%Module1.0
proc ModulesHelp { } {
global version
puts stderr "ALICE Modulefile for $PKGNAME $PKGVERSION-@@PKGREVISION@$PKGHASH@@"
}
set version $PKGVERSION-@@PKGREVISION@$PKGHASH@@
module-whatis "ALICE Modulefile for $PKGNAME $PKGVERSION-@@PKGREVISION@$PKGHASH@@"
# Dependencies
module load BASE/1.0 \\
${FAIRLOGGER_REVISION:+FairLogger/$FAIRLOGGER_VERSION-$FAIRLOGGER_REVISION} \\
${FAIRMQ_REVISION:+FairMQ/$FAIRMQ_VERSION-$FAIRMQ_REVISION} \\
${GEANT3_REVISION:+GEANT3/$GEANT3_VERSION-$GEANT3_REVISION} \\
${GEANT4_VMC_REVISION:+GEANT4_VMC/$GEANT4_VMC_VERSION-$GEANT4_VMC_REVISION} \\
${PROTOBUF_REVISION:+protobuf/$PROTOBUF_VERSION-$PROTOBUF_REVISION} \\
${PYTHIA6_REVISION:+pythia6/$PYTHIA6_VERSION-$PYTHIA6_REVISION} \\
${PYTHIA_REVISION:+pythia/$PYTHIA_VERSION-$PYTHIA_REVISION} \\
${VGM_REVISION:+vgm/$VGM_VERSION-$VGM_REVISION} \\
${BOOST_REVISION:+boost/$BOOST_VERSION-$BOOST_REVISION} \\
ROOT/$ROOT_VERSION-$ROOT_REVISION \\
${ZEROMQ_REVISION:+ZeroMQ/$ZEROMQ_VERSION-$ZEROMQ_REVISION} \\
${DDS_REVISION:+DDS/$DDS_VERSION-$DDS_REVISION} \\
${GCC_TOOLCHAIN_REVISION:+GCC-Toolchain/$GCC_TOOLCHAIN_VERSION-$GCC_TOOLCHAIN_REVISION}
# Our environment
set FAIRROOT_ROOT \$::env(BASEDIR)/$PKGNAME/\$version
setenv VMCWORKDIR \$FAIRROOT_ROOT/share/fairbase/examples
setenv GEOMPATH \$::env(VMCWORKDIR)/common/geometry
setenv CONFIG_DIR \$::env(VMCWORKDIR)/common/gconfig
prepend-path PATH \$FAIRROOT_ROOT/bin
prepend-path LD_LIBRARY_PATH \$FAIRROOT_ROOT/lib
prepend-path ROOT_INCLUDE_PATH \$FAIRROOT_ROOT/include
EoF