2017-10-29 00:47:46 +01:00
|
|
|
{ stdenv, buildPythonPackage, isPy27, isPyPy, fetchPypi, libffi, pycparser, pytest }:
|
2017-05-01 16:50:55 +01:00
|
|
|
|
|
|
|
if isPyPy then null else buildPythonPackage rec {
|
|
|
|
pname = "cffi";
|
2018-01-20 10:57:30 +00:00
|
|
|
version = "1.11.4";
|
2017-05-01 16:50:55 +01:00
|
|
|
name = "${pname}-${version}";
|
|
|
|
|
|
|
|
src = fetchPypi {
|
|
|
|
inherit pname version;
|
2018-01-20 10:57:30 +00:00
|
|
|
sha256 = "df9083a992b17a28cd4251a3f5c879e0198bb26c9e808c4647e0a18739f1d11d";
|
2017-05-01 16:50:55 +01:00
|
|
|
};
|
|
|
|
|
2017-10-29 00:47:46 +01:00
|
|
|
patches = stdenv.lib.optional (isPy27 && stdenv.cc.isClang) ./clang.patch;
|
|
|
|
|
2017-09-27 10:25:50 +01:00
|
|
|
outputs = [ "out" "dev" ];
|
|
|
|
|
2017-05-01 16:50:55 +01:00
|
|
|
propagatedBuildInputs = [ libffi pycparser ];
|
|
|
|
buildInputs = [ pytest ];
|
|
|
|
|
2017-10-31 11:20:22 +00:00
|
|
|
# On Darwin, the cffi tests want to hit libm a lot, and look for it in a global
|
|
|
|
# impure search path. It's obnoxious how much repetition there is, and how difficult
|
|
|
|
# it is to get it to search somewhere else (since we do actually have a libm symlink in libSystem)
|
|
|
|
prePatch = stdenv.lib.optionalString stdenv.isDarwin ''
|
|
|
|
substituteInPlace testing/cffi0/test_parsing.py \
|
|
|
|
--replace 'lib_m = "m"' 'lib_m = "System"' \
|
|
|
|
--replace '"libm" in name' '"libSystem" in name'
|
|
|
|
substituteInPlace testing/cffi0/test_unicode_literals.py --replace 'lib_m = "m"' 'lib_m = "System"'
|
|
|
|
substituteInPlace testing/cffi0/test_zdistutils.py --replace 'self.lib_m = "m"' 'self.lib_m = "System"'
|
|
|
|
substituteInPlace testing/cffi1/test_recompiler.py --replace 'lib_m = "m"' 'lib_m = "System"'
|
|
|
|
substituteInPlace testing/cffi0/test_function.py --replace "lib_m = 'm'" "lib_m = 'System'"
|
|
|
|
substituteInPlace testing/cffi0/test_verify.py --replace "lib_m = ['m']" "lib_m = ['System']"
|
|
|
|
'';
|
|
|
|
|
2017-09-16 15:27:33 +01:00
|
|
|
# The tests use -Werror but with python3.6 clang detects some unreachable code.
|
2017-10-29 00:47:46 +01:00
|
|
|
NIX_CFLAGS_COMPILE = stdenv.lib.optionals stdenv.cc.isClang [ "-Wno-unused-command-line-argument" "-Wno-unreachable-code" ];
|
2017-05-01 16:50:55 +01:00
|
|
|
|
|
|
|
checkPhase = ''
|
|
|
|
py.test
|
|
|
|
'';
|
|
|
|
|
2017-09-16 15:27:33 +01:00
|
|
|
meta = with stdenv.lib; {
|
2017-05-01 16:50:55 +01:00
|
|
|
maintainers = with maintainers; [ domenkozar ];
|
|
|
|
homepage = https://cffi.readthedocs.org/;
|
|
|
|
license = with licenses; [ mit ];
|
|
|
|
description = "Foreign Function Interface for Python calling C code";
|
|
|
|
};
|
|
|
|
}
|