{ lib , stdenv , buildPythonPackage , isPyPy , fetchPypi , fetchpatch , pytestCheckHook , libffi , pkg-config , pycparser , pythonAtLeast }: if isPyPy then null else buildPythonPackage rec { pname = "cffi"; version = "1.15.1"; src = fetchPypi { inherit pname version; sha256 = "sha256-1AC/uaN7E1ElPLQCZxzqfom97MKU6AFqcH9tHYrJNPk="; }; patches = [ # # Trusts the libffi library inside of nixpkgs on Apple devices. # # Based on some analysis I did: # # https://groups.google.com/g/python-cffi/c/xU0Usa8dvhk # # I believe that libffi already contains the code from Apple's fork that is # deemed safe to trust in cffi. # ./darwin-use-libffi-closures.diff (fetchpatch { # Drop py.code usage from tests, no longer depend on the deprecated py package url = "https://foss.heptapod.net/pypy/cffi/-/commit/9c7d865e17ec16a847090a3e0d1498b698b99756.patch"; excludes = [ "README.md" "requirements.txt" ]; hash = "sha256-HSuLLIYXXGGCPccMNLV7o1G3ppn2P0FGCrPjqDv2e7k="; }) (fetchpatch { # Replace py.test usage with pytest url = "https://foss.heptapod.net/pypy/cffi/-/commit/bd02e1b122612baa74a126e428bacebc7889e897.patch"; excludes = [ "README.md" "requirements.txt" ]; hash = "sha256-+2daRTvxtyrCPimOEAmVbiVm1Bso9hxGbaAbd03E+ws="; }) ] ++ lib.optionals (pythonAtLeast "3.11") [ # Fix test that failed because python seems to have changed the exception format in the # final release. This patch should be included in the next version and can be removed when # it is released. (fetchpatch { url = "https://foss.heptapod.net/pypy/cffi/-/commit/8a3c2c816d789639b49d3ae867213393ed7abdff.diff"; sha256 = "sha256-3wpZeBqN4D8IP+47QDGK7qh/9Z0Ag4lAe+H0R5xCb1E="; }) ]; postPatch = lib.optionalString stdenv.isDarwin '' # Remove setup.py impurities substituteInPlace setup.py \ --replace "'-iwithsysroot/usr/include/ffi'" "" \ --replace "'/usr/include/ffi'," "" \ --replace '/usr/include/libffi' '${lib.getDev libffi}/include' ''; buildInputs = [ libffi ]; nativeBuildInputs = [ pkg-config ]; propagatedBuildInputs = [ pycparser ]; # The tests use -Werror but with python3.6 clang detects some unreachable code. env.NIX_CFLAGS_COMPILE = lib.optionalString stdenv.cc.isClang "-Wno-unused-command-line-argument -Wno-unreachable-code -Wno-c++11-narrowing"; doCheck = !stdenv.hostPlatform.isMusl; nativeCheckInputs = [ pytestCheckHook ]; disabledTests = lib.optionals stdenv.isDarwin [ # AssertionError: cannot seem to get an int[10] not completely cleared # https://foss.heptapod.net/pypy/cffi/-/issues/556 "test_ffi_new_allocator_1" ]; meta = with lib; { maintainers = with maintainers; [ domenkozar lnl7 ]; homepage = "https://cffi.readthedocs.org/"; license = licenses.mit; description = "Foreign Function Interface for Python calling C code"; }; }