Merge pull request #47915 from timokau/zn_poly-update
zn_poly: 0.9 -> 0.9.1
This commit is contained in:
commit
a00b7de165
@ -1,17 +1,25 @@
|
|||||||
{ stdenv
|
{ stdenv
|
||||||
, fetchurl
|
, lib
|
||||||
|
, fetchFromGitLab
|
||||||
|
, fetchpatch
|
||||||
, gmp
|
, gmp
|
||||||
, python2
|
, python2
|
||||||
|
, tune ? false # tune to hardware, impure
|
||||||
}:
|
}:
|
||||||
|
|
||||||
stdenv.mkDerivation rec {
|
stdenv.mkDerivation rec {
|
||||||
version = "0.9";
|
version = "0.9.1";
|
||||||
pname = "zn_poly";
|
pname = "zn_poly";
|
||||||
name = "${pname}-${version}";
|
name = "${pname}-${version}";
|
||||||
|
|
||||||
src = fetchurl {
|
# sage has picked up the maintenance (bug fixes and building, not development)
|
||||||
url = "http://web.maths.unsw.edu.au/~davidharvey/code/zn_poly/releases/zn_poly-${version}.tar.gz";
|
# from the original, now unmaintained project which can be found at
|
||||||
sha256 = "1kxl25av7i3v68k32hw5bayrfcvmahmqvs97mlh9g238gj4qb851";
|
# http://web.maths.unsw.edu.au/~davidharvey/code/zn_poly/
|
||||||
|
src = fetchFromGitLab {
|
||||||
|
owner = "sagemath";
|
||||||
|
repo = "zn_poly";
|
||||||
|
rev = version;
|
||||||
|
sha256 = "0ra5vy585bqq7g3317iw6fp44iqgqvds3j0l1va6mswimypq4vxb";
|
||||||
};
|
};
|
||||||
|
|
||||||
buildInputs = [
|
buildInputs = [
|
||||||
@ -22,27 +30,42 @@ stdenv.mkDerivation rec {
|
|||||||
python2 # needed by ./configure to create the makefile
|
python2 # needed by ./configure to create the makefile
|
||||||
];
|
];
|
||||||
|
|
||||||
libname = "libzn_poly${stdenv.targetPlatform.extensions.sharedLibrary}";
|
# name of library file ("libzn_poly.so")
|
||||||
|
libbasename = "libzn_poly";
|
||||||
|
libext = "${stdenv.targetPlatform.extensions.sharedLibrary}";
|
||||||
|
|
||||||
makeFlags = [ "CC=cc" ];
|
makeFlags = [ "CC=cc" ];
|
||||||
|
|
||||||
# Tuning (either autotuning or with hand-written paramters) is possible
|
# Tuning (either autotuning or with hand-written paramters) is possible
|
||||||
# but not implemented here.
|
# but not implemented here.
|
||||||
# It seems buggy anyways (see homepage).
|
# It seems buggy anyways (see homepage).
|
||||||
buildFlags = [ "all" libname ];
|
buildFlags = [ "all" "${libbasename}${libext}" ];
|
||||||
|
|
||||||
|
configureFlags = lib.optionals (!tune) [
|
||||||
|
"--disable-tuning"
|
||||||
|
];
|
||||||
|
|
||||||
|
patches = [
|
||||||
|
# fix format-security by not passing variables directly to printf
|
||||||
|
# https://gitlab.com/sagemath/zn_poly/merge_requests/1
|
||||||
|
(fetchpatch {
|
||||||
|
name = "format-security.patch";
|
||||||
|
url = "https://gitlab.com/timokau/zn_poly/commit/1950900a80ec898d342b8bcafa148c8027649766.patch";
|
||||||
|
sha256 = "1gks9chvsfpc6sg5h3nqqfia4cgvph7jmj9dw67k7dk7kv9y0rk1";
|
||||||
|
})
|
||||||
|
];
|
||||||
|
|
||||||
# `make install` fails to install some header files and the lib file.
|
# `make install` fails to install some header files and the lib file.
|
||||||
installPhase = ''
|
installPhase = ''
|
||||||
mkdir -p "$out/include/zn_poly"
|
mkdir -p "$out/include/zn_poly"
|
||||||
mkdir -p "$out/lib"
|
mkdir -p "$out/lib"
|
||||||
cp "${libname}" "$out/lib"
|
cp "${libbasename}"*"${libext}" "$out/lib"
|
||||||
cp include/*.h "$out/include/zn_poly"
|
cp include/*.h "$out/include/zn_poly"
|
||||||
'';
|
'';
|
||||||
|
|
||||||
doCheck = true;
|
doCheck = true;
|
||||||
|
|
||||||
meta = with stdenv.lib; {
|
meta = with lib; {
|
||||||
homepage = http://web.maths.unsw.edu.au/~davidharvey/code/zn_poly/;
|
homepage = http://web.maths.unsw.edu.au/~davidharvey/code/zn_poly/;
|
||||||
description = "Polynomial arithmetic over Z/nZ";
|
description = "Polynomial arithmetic over Z/nZ";
|
||||||
license = with licenses; [ gpl3 ];
|
license = with licenses; [ gpl3 ];
|
||||||
|
Loading…
Reference in New Issue
Block a user