nixpkgs/pkgs/development/python-modules/pexpect/default.nix

49 lines
1.7 KiB
Nix
Raw Normal View History

2017-11-25 15:27:31 +00:00
{ lib
, buildPythonPackage
, fetchPypi
, ptyprocess
, isPy3k
2017-11-25 15:27:31 +00:00
}:
buildPythonPackage (rec {
2017-11-25 15:27:31 +00:00
pname = "pexpect";
2020-06-06 07:47:21 +01:00
version = "4.8.0";
2017-11-25 15:27:31 +00:00
src = fetchPypi {
inherit pname version;
2020-06-06 07:47:21 +01:00
sha256 = "fc65a43959d153d0114afe13997d439c22823a27cefceb5ff35c2178c6784c0c";
2017-11-25 15:27:31 +00:00
};
# Wants to run pythonin a subprocess
doCheck = false;
propagatedBuildInputs = [ ptyprocess ];
meta = with lib; {
homepage = "http://www.noah.org/wiki/Pexpect";
2017-11-25 15:27:31 +00:00
description = "Automate interactive console applications such as ssh, ftp, etc";
license = licenses.mit;
maintainers = with maintainers; [ zimbatm ];
longDescription = ''
Pexpect is similar to the Don Libes "Expect" system, but Pexpect
as a different interface that is easier to understand. Pexpect
is basically a pattern matching system. It runs programs and
watches output. When output matches a given pattern Pexpect can
respond as if a human were typing responses. Pexpect can be used
for automation, testing, and screen scraping. Pexpect can be
used for automating interactive console applications such as
ssh, ftp, passwd, telnet, etc. It can also be used to control
web applications via "lynx", "w3m", or some other text-based web
browser. Pexpect is pure Python. Unlike other Expect-like
modules for Python Pexpect does not require TCL or Expect nor
does it require C extensions to be compiled. It should work on
any platform that supports the standard Python pty module.
'';
};
# TODO: move into main set, this was to avoid a rebuild
} // lib.optionalAttrs (!isPy3k ) {
# syntax error in _async module, likely intended only for Python 3.
dontUsePythonRecompileBytecode = !isPy3k;
})