nixpkgs/pkgs/development/python-modules/pygatt/default.nix
adisbladis 02dab4ab5c python3.pkgs.*: Explicitly pass buildPythonPackage format parameter
Long term we should move everything over to `pyproject = true`, but in
the mean time we can work towards deprecating the implicit `format` paremeter.

cc https://github.com/NixOS/nixpkgs/issues/253154
cc @mweinelt @figsoda
2023-12-07 17:46:49 +01:00

60 lines
1.2 KiB
Nix

{ lib
, buildPythonPackage
, fetchFromGitHub
, mock
, nose
, pexpect
, pyserial
, pytestCheckHook
, pythonOlder
}:
buildPythonPackage rec {
pname = "pygatt";
version = "4.0.5";
format = "setuptools";
disabled = pythonOlder "3.5";
src = fetchFromGitHub {
owner = "peplin";
repo = pname;
rev = "v${version}";
sha256 = "1zdfxidiw0l8n498sy0l33n90lz49n25x889cx6jamjr7frlcihd";
};
propagatedBuildInputs = [
pyserial
];
passthru.optional-dependencies.GATTTOOL = [
pexpect
];
nativeBuildInputs = [
# For cross compilation the doCheck is false and therefor the
# nativeCheckInputs not included. We have to include nose here, since
# setup.py requires nose unconditionally.
nose
];
nativeCheckInputs = [
mock
pytestCheckHook
]
++ passthru.optional-dependencies.GATTTOOL;
postPatch = ''
# Not support for Python < 3.4
substituteInPlace setup.py --replace "'enum-compat'" ""
'';
pythonImportsCheck = [ "pygatt" ];
meta = with lib; {
description = "Python wrapper the BGAPI for accessing Bluetooth LE Devices";
homepage = "https://github.com/peplin/pygatt";
license = with licenses; [ asl20 mit ];
maintainers = with maintainers; [ fab ];
};
}