summaryrefslogtreecommitdiff
path: root/var
diff options
context:
space:
mode:
authoriarspider <iarspider@gmail.com>2020-10-22 17:56:53 +0200
committerGitHub <noreply@github.com>2020-10-22 10:56:53 -0500
commit601636b75595031ef9478297f9a52132a9bff9eb (patch)
tree896d043dae14af0c3f856a2f07c127fcc3a05d92 /var
parent019205ec7afcd8f55ebf52cb21d8090161e99738 (diff)
downloadspack-601636b75595031ef9478297f9a52132a9bff9eb.tar.gz
spack-601636b75595031ef9478297f9a52132a9bff9eb.tar.bz2
spack-601636b75595031ef9478297f9a52132a9bff9eb.tar.xz
spack-601636b75595031ef9478297f9a52132a9bff9eb.zip
Add herwig3 (#19406)
* Add recipe for qgraf * Revert "Add recipe for qgraf" This reverts commit 76783f73867a32b4a96e980e31a433ed3c0037fd. * Add herwig3 * Prepare fixes based on MR (needs checking) * Set all dependencies (except python) as build-type * OK now * Move import to the top of the file * Fix dependency name Co-authored-by: Ivan Razumov <ivan.razumov@cern.ch>
Diffstat (limited to 'var')
-rw-r--r--var/spack/repos/builtin/packages/herwig3/package.py97
1 files changed, 97 insertions, 0 deletions
diff --git a/var/spack/repos/builtin/packages/herwig3/package.py b/var/spack/repos/builtin/packages/herwig3/package.py
new file mode 100644
index 0000000000..6f529c10bf
--- /dev/null
+++ b/var/spack/repos/builtin/packages/herwig3/package.py
@@ -0,0 +1,97 @@
+# Copyright 2013-2020 Lawrence Livermore National Security, LLC and other
+# Spack Project Developers. See the top-level COPYRIGHT file for details.
+#
+# SPDX-License-Identifier: (Apache-2.0 OR MIT)
+
+from spack import *
+import shutil
+
+
+class Herwig3(AutotoolsPackage):
+ """Herwig is a multi-purpose particle physics event generator."""
+
+ homepage = "https://herwig.hepforge.org"
+ url = "https://herwig.hepforge.org/downloads/Herwig-7.2.1.tar.bz2"
+
+ version('7.2.1', sha256='d4fff32f21c5c08a4b2e563c476b079859c2c8e3b78d853a8a60da96d5eea686')
+
+ depends_on('autoconf', type='build')
+ depends_on('automake', type='build')
+ depends_on('libtool', type='build')
+ depends_on('m4', type='build')
+ depends_on('lhapdf', type='link')
+ depends_on('thepeg@2.2.1', when='@7.2.1', type='link')
+ depends_on('boost', type='link')
+ depends_on('python', type=('build', 'run'))
+ depends_on('gsl', type='link')
+ depends_on('fastjet', type='link')
+ depends_on('vbfnlo@3:', type='link')
+ depends_on('madgraph5amc', type='link')
+ depends_on('njet', type='link')
+ depends_on('py-gosam', type='link', when='^python@2.7:2.7.99')
+ depends_on('gosam-contrib', type='link')
+ depends_on('openloops', type='link')
+
+ force_autoreconf = True
+
+ def autoreconf(self, spec, prefix):
+ autoreconf('--install', '--verbose', '--force')
+
+ @run_before('build')
+ def install_lhapdfsets(self):
+ mkdirp(self.prefix.tmppdfsets)
+ lhapdf = which('lhapdf')
+ if self.spec.satisfies('@7.2.0:'):
+ lhapdf("--pdfdir=" + self.prefix.tmppdfsets,
+ # "--source=/cvmfs/sft.cern.ch/lcg/external/lhapdfsets/current",
+ # "--listdir=/cvmfs/sft.cern.ch/lcg/external/lhapdfsets/current",
+ "install", "MHT2014lo68cl", "MMHT2014nlo68cl",
+ "CT14lo", "CT14nlo")
+
+ def configure_args(self):
+ args = ['--with-gsl=' + self.spec['gsl'].prefix,
+ '--with-thepeg=' + self.spec['thepeg'].prefix,
+ '--with-thepeg-headers=' + self.spec['thepeg'].prefix.include,
+ '--with-fastjet=' + self.spec['fastjet'].prefix,
+ '--with-boost=' + self.spec['boost'].prefix,
+ '--with-madgraph=' + self.spec['madgraph5amc'].prefix,
+ '--with-openloops=' + self.spec['openloops'].prefix,
+ '--with-gosam-contrib=' + self.spec['gosam-contrib'].prefix,
+ '--with-njet=' + self.spec['njet'].prefix,
+ '--with-vbfnlo=' + self.spec['vbfnlo'].prefix]
+
+ if self.spec.satisfies('^python@2.7:2.7.99'):
+ args.append('--with-gosam=' + self.spec['gosam'].prefix)
+
+ return args
+
+ def flag_handler(self, name, flags):
+ if name == 'fcflags':
+ flags.append('-std=legacy')
+ return (None, flags, None)
+ elif name in ['cflags', 'cxxflags', 'cppflags']:
+ return (None, flags, None)
+
+ return (flags, None, None)
+
+ def setup_build_environment(self, env):
+ thepeg_home = self.spec['thepeg'].prefix
+ env.prepend_path('LD_LIBRARY_PATH', thepeg_home.lib.ThePEG)
+ env.set('LHAPDF_DATA_PATH', self.prefix.tmppdfsets)
+ env.set('HERWIGINCLUDE', '-I' + self.prefix.include)
+ env.set('BOOSTINCLUDE', '-I' + self.spec['boost'].prefix.include)
+ env.set('HERWIGINSTALL', self.prefix)
+
+ def build(self, spec, prefix):
+ make()
+ with working_dir('MatrixElement/FxFx'):
+ make()
+
+ def install(self, spec, prefix):
+ make('install')
+ with working_dir('MatrixElement/FxFx'):
+ make('install')
+
+ @run_after('install')
+ def remove_lhapdfsets(self):
+ shutil.rmtree(self.prefix.tmppdfsets)