mirror of
https://github.com/NixOS/nixpkgs.git
synced 2024-12-01 19:33:03 +00:00
rivet: init at 2.5.0
This commit is contained in:
parent
571d1111fe
commit
334b9e2a40
73
pkgs/development/libraries/physics/rivet/default.nix
Normal file
73
pkgs/development/libraries/physics/rivet/default.nix
Normal file
@ -0,0 +1,73 @@
|
|||||||
|
{ stdenv, fetchurl, fastjet, ghostscript, gsl, hepmc, imagemagick, less, python, texlive, yoda, which, makeWrapper }:
|
||||||
|
|
||||||
|
stdenv.mkDerivation rec {
|
||||||
|
name = "rivet-${version}";
|
||||||
|
version = "2.5.2";
|
||||||
|
|
||||||
|
src = fetchurl {
|
||||||
|
url = "http://www.hepforge.org/archive/rivet/Rivet-${version}.tar.bz2";
|
||||||
|
sha256 = "01agf0bswqvci8nwp67kvrlwc2k0sg1s0lxpq2a9q58l99v2gakh";
|
||||||
|
};
|
||||||
|
|
||||||
|
pythonPath = []; # python wrapper support
|
||||||
|
|
||||||
|
patches = [
|
||||||
|
./key_val.patch
|
||||||
|
./zaxis_fix.patch
|
||||||
|
];
|
||||||
|
|
||||||
|
latex = texlive.combine { inherit (texlive)
|
||||||
|
scheme-basic
|
||||||
|
collection-pstricks
|
||||||
|
collection-fontsrecommended
|
||||||
|
mathastext
|
||||||
|
pgf
|
||||||
|
relsize
|
||||||
|
sfmath
|
||||||
|
xcolor
|
||||||
|
xkeyval
|
||||||
|
;};
|
||||||
|
buildInputs = [ ghostscript hepmc imagemagick python latex makeWrapper ];
|
||||||
|
propagatedBuildInputs = [ fastjet gsl yoda ];
|
||||||
|
|
||||||
|
preInstall = ''
|
||||||
|
substituteInPlace bin/make-plots \
|
||||||
|
--replace '"which"' '"${which}/bin/which"' \
|
||||||
|
--replace '"latex"' '"${latex}/bin/latex"' \
|
||||||
|
--replace '"dvips"' '"${latex}/bin/dvips"' \
|
||||||
|
--replace '"ps2pdf"' '"${ghostscript}/bin/ps2pdf"' \
|
||||||
|
--replace '"ps2eps"' '"${ghostscript}/bin/ps2eps"' \
|
||||||
|
--replace '"kpsewhich"' '"${latex}/bin/kpsewhich"' \
|
||||||
|
--replace '"convert"' '"${imagemagick.out}/bin/convert"'
|
||||||
|
substituteInPlace bin/rivet \
|
||||||
|
--replace '"less"' '"${less}/bin/less"'
|
||||||
|
substituteInPlace bin/rivet-buildplugin \
|
||||||
|
--replace '"which"' '"${which}/bin/which"' \
|
||||||
|
--replace 'mycxx=' 'mycxx=${stdenv.cc}/bin/${if stdenv.cc.isClang or false then "clang++" else "g++"} #' \
|
||||||
|
--replace 'mycxxflags="' "mycxxflags=\"-std=c++11 $NIX_CFLAGS_COMPILE $NIX_CXXSTDLIB_COMPILE $NIX_CFLAGS_LINK "
|
||||||
|
substituteInPlace bin/rivet-mkhtml \
|
||||||
|
--replace '"make-plots"' \"$out/bin/make-plots\" \
|
||||||
|
--replace '"rivet-cmphistos"' \"$out/bin/rivet-cmphistos\"
|
||||||
|
'';
|
||||||
|
|
||||||
|
configureFlags = [
|
||||||
|
"--with-fastjet=${fastjet}"
|
||||||
|
"--with-hepmc=${hepmc}"
|
||||||
|
"--with-yoda=${yoda}"
|
||||||
|
];
|
||||||
|
|
||||||
|
enableParallelBuilding = true;
|
||||||
|
|
||||||
|
postInstall = ''
|
||||||
|
for prog in "$out"/bin/*; do
|
||||||
|
wrapProgram "$prog" --set PYTHONPATH $PYTHONPATH:$(toPythonPath "$out")
|
||||||
|
done
|
||||||
|
'';
|
||||||
|
|
||||||
|
meta = {
|
||||||
|
description = "A framework for comparison of experimental measurements from high-energy particle colliders to theory predictions";
|
||||||
|
license = stdenv.lib.licenses.gpl2;
|
||||||
|
homepage = https://rivet.hepforge.org;
|
||||||
|
platforms = stdenv.lib.platforms.unix;
|
||||||
|
};
|
||||||
|
}
|
12
pkgs/development/libraries/physics/rivet/key_val.patch
Normal file
12
pkgs/development/libraries/physics/rivet/key_val.patch
Normal file
@ -0,0 +1,12 @@
|
|||||||
|
diff --git a/bin/rivet-cmphistos b/bin/rivet-cmphistos
|
||||||
|
--- a/bin/rivet-cmphistos
|
||||||
|
+++ b/bin/rivet-cmphistos
|
||||||
|
@@ -371,7 +371,7 @@ if __name__ == '__main__':
|
||||||
|
# plot[key] = val
|
||||||
|
if plotoptions.has_key("PLOT"):
|
||||||
|
for key_val in plotoptions["PLOT"]:
|
||||||
|
- key, val = [s.strip() for s in key_val.split("=")]
|
||||||
|
+ key, val = [s.strip() for s in key_val.split("=", 1)]
|
||||||
|
plot[key] = val
|
||||||
|
if opts.LINEAR:
|
||||||
|
plot['LogY'] = '0'
|
42
pkgs/development/libraries/physics/rivet/zaxis_fix.patch
Normal file
42
pkgs/development/libraries/physics/rivet/zaxis_fix.patch
Normal file
@ -0,0 +1,42 @@
|
|||||||
|
diff --git a/bin/make-plots b/bin/make-plots
|
||||||
|
index abb024d..f59293d 100755
|
||||||
|
--- a/bin/make-plots
|
||||||
|
+++ b/bin/make-plots
|
||||||
|
@@ -1152,8 +1152,8 @@ class ColorScale(Described):
|
||||||
|
|
||||||
|
zcustommajortickmarks = int(self.description.get('ZMajorTickMarks', -1))
|
||||||
|
zcustomminortickmarks = int(self.description.get('ZMinorTickMarks', -1))
|
||||||
|
- zcustommajorticks=[]
|
||||||
|
- zcustomminorticks=[]
|
||||||
|
+ zcustommajorticks=None
|
||||||
|
+ zcustomminorticks=None
|
||||||
|
if self.description.has_key('ZCustomMajorTicks') and self.description['ZCustomMajorTicks']!='':
|
||||||
|
# TODO: Would be nice to have less invisible separation of the custom ticks than split on tabs
|
||||||
|
ticks = self.description['ZCustomMajorTicks'].strip().split('\t')
|
||||||
|
@@ -2214,7 +2214,7 @@ class Ticks(object):
|
||||||
|
|
||||||
|
class XTicks(Ticks):
|
||||||
|
|
||||||
|
- def draw(self, custommajorticks=[], customminorticks=[], custommajortickmarks=-1, customminortickmarks=-1,drawlabels=True):
|
||||||
|
+ def draw(self, custommajorticks=None, customminorticks=None, custommajortickmarks=-1, customminortickmarks=-1,drawlabels=True):
|
||||||
|
twosided = bool(int(self.description.get('XTwosidedTicks', '0')))
|
||||||
|
out = ""
|
||||||
|
out += ('\n%\n% X-Ticks\n%\n')
|
||||||
|
@@ -2265,7 +2265,7 @@ class XTicks(Ticks):
|
||||||
|
|
||||||
|
class YTicks(Ticks):
|
||||||
|
|
||||||
|
- def draw(self, custommajorticks=[], customminorticks=[], custommajortickmarks=-1, customminortickmarks=-1, drawlabels=True):
|
||||||
|
+ def draw(self, custommajorticks=None, customminorticks=None, custommajortickmarks=-1, customminortickmarks=-1, drawlabels=True):
|
||||||
|
twosided = bool(int(self.description.get('YTwosidedTicks', '0')))
|
||||||
|
out = ""
|
||||||
|
out += ('\n%\n% Y-Ticks\n%\n')
|
||||||
|
@@ -2320,7 +2320,7 @@ class ZTicks(Ticks):
|
||||||
|
self.description = description
|
||||||
|
self.coors = coors
|
||||||
|
|
||||||
|
- def draw(self, custommajorticks=[], customminorticks=[],
|
||||||
|
+ def draw(self, custommajorticks=None, customminorticks=None,
|
||||||
|
custommajortickmarks=-1, customminortickmarks=-1,
|
||||||
|
drawlabels=True):
|
||||||
|
out = ""
|
@ -16719,6 +16719,8 @@ in
|
|||||||
|
|
||||||
hepmc = callPackage ../development/libraries/physics/hepmc { };
|
hepmc = callPackage ../development/libraries/physics/hepmc { };
|
||||||
|
|
||||||
|
rivet = callPackage ../development/libraries/physics/rivet { };
|
||||||
|
|
||||||
yoda = callPackage ../development/libraries/physics/yoda { };
|
yoda = callPackage ../development/libraries/physics/yoda { };
|
||||||
|
|
||||||
### MISC
|
### MISC
|
||||||
|
Loading…
Reference in New Issue
Block a user