summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorGregory P. Smith <greg@mad-scientist.com>2008-04-21 21:31:08 +0000
committerGregory P. Smith <greg@mad-scientist.com>2008-04-21 21:31:08 +0000
commit41e30183367e52450fdf7316cf32bfa4e9a78afc (patch)
treef643e5118416fb35af9d9d17b022d43d5f110652
parentaa3cadb01e47719b9f8b7401cdbd32791b5e16f7 (diff)
downloadcpython-git-41e30183367e52450fdf7316cf32bfa4e9a78afc.tar.gz
If sys.stdin is not a tty, fall back to default_getpass after printing
a warning instead of failing with a termios.error.
-rw-r--r--Lib/getpass.py4
-rw-r--r--Misc/NEWS3
2 files changed, 7 insertions, 0 deletions
diff --git a/Lib/getpass.py b/Lib/getpass.py
index 6b786122ec..07c89ff0b9 100644
--- a/Lib/getpass.py
+++ b/Lib/getpass.py
@@ -24,6 +24,10 @@ def unix_getpass(prompt='Password: ', stream=None):
if stream is None:
stream = sys.stdout
+ if not sys.stdin.isatty():
+ print >>sys.stderr, "Warning: sys.stdin is not a tty."
+ return default_getpass(prompt)
+
try:
fd = sys.stdin.fileno()
except:
diff --git a/Misc/NEWS b/Misc/NEWS
index 660651a86b..51f6ce14c8 100644
--- a/Misc/NEWS
+++ b/Misc/NEWS
@@ -37,6 +37,9 @@ Extensions Modules
Library
-------
+- getpass.getpass() now works when sys.stdin is not a tty by printing a warning
+ and falling back to sys.stdin.readline instead of raising termios.error.
+
- Issue #2014: Allow XML-RPC datetime objects to have dates before
1900-01-01.