2018-10-26 14:30:06 +01:00
|
|
|
{ stdenv
|
|
|
|
, buildPythonPackage
|
|
|
|
, fetchPypi
|
2020-01-23 01:14:52 +00:00
|
|
|
, enchant2
|
2018-10-26 14:30:06 +01:00
|
|
|
}:
|
|
|
|
|
|
|
|
buildPythonPackage rec {
|
|
|
|
pname = "pyenchant";
|
2018-11-04 10:35:11 +00:00
|
|
|
version = "2.0.0";
|
2018-10-26 14:30:06 +01:00
|
|
|
|
|
|
|
src = fetchPypi {
|
|
|
|
inherit pname version;
|
2018-11-04 10:35:11 +00:00
|
|
|
sha256 = "fc31cda72ace001da8fe5d42f11c26e514a91fa8c70468739216ddd8de64e2a0";
|
2018-10-26 14:30:06 +01:00
|
|
|
};
|
|
|
|
|
2020-01-23 01:14:52 +00:00
|
|
|
propagatedBuildInputs = [ enchant2 ];
|
2018-10-26 14:30:06 +01:00
|
|
|
|
2020-01-23 01:14:52 +00:00
|
|
|
postPatch = let
|
|
|
|
libext = stdenv.hostPlatform.extensions.sharedLibrary;
|
2018-10-26 14:30:06 +01:00
|
|
|
in ''
|
2020-01-23 01:14:52 +00:00
|
|
|
# Use the $PYENCHANT_LIBRARY_PATH envvar lookup line to hard-code the
|
|
|
|
# location of the nix enchant-2 library into _enchant.py.
|
|
|
|
#
|
|
|
|
# Also, they hardcode a bad path for Darwin in their library search code;
|
|
|
|
# This code should never be hit, but in case it does, we don't want to have
|
|
|
|
# it "accidentally" work by pulling something from /opt.
|
|
|
|
substituteInPlace enchant/_enchant.py \
|
|
|
|
--replace 'os.environ.get("PYENCHANT_LIBRARY_PATH")' \
|
|
|
|
"'${enchant2}/lib/libenchant-2${libext}'" \
|
|
|
|
--replace '/opt/local/lib/' ""
|
2018-10-26 14:30:06 +01:00
|
|
|
'';
|
|
|
|
|
|
|
|
# dictionaries needed for tests
|
|
|
|
doCheck = false;
|
|
|
|
|
|
|
|
meta = with stdenv.lib; {
|
|
|
|
description = "pyenchant: Python bindings for the Enchant spellchecker";
|
2020-01-10 20:17:37 +00:00
|
|
|
homepage = https://github.com/pyenchant/pyenchant;
|
2018-10-26 14:30:06 +01:00
|
|
|
license = licenses.lgpl21;
|
|
|
|
};
|
|
|
|
|
|
|
|
}
|