44 lines
1.5 KiB
Nix
44 lines
1.5 KiB
Nix
{ lib
|
|
, buildPythonPackage
|
|
, fetchPypi
|
|
, ptyprocess
|
|
}:
|
|
|
|
buildPythonPackage rec {
|
|
pname = "pexpect";
|
|
version = "4.4.0";
|
|
name = "${pname}-${version}";
|
|
|
|
src = fetchPypi {
|
|
inherit pname version;
|
|
sha256 = "67b85a1565968e3d5b5e7c9283caddc90c3947a2625bed1905be27bd5a03e47d";
|
|
};
|
|
|
|
# Wants to run pythonin a subprocess
|
|
doCheck = false;
|
|
|
|
propagatedBuildInputs = [ ptyprocess ];
|
|
|
|
meta = with lib; {
|
|
homepage = http://www.noah.org/wiki/Pexpect;
|
|
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.
|
|
'';
|
|
};
|
|
}
|