diff options
| author | Amaury Forgeot d'Arc <amauryfa@gmail.com> | 2008-09-21 21:49:01 +0000 | 
|---|---|---|
| committer | Amaury Forgeot d'Arc <amauryfa@gmail.com> | 2008-09-21 21:49:01 +0000 | 
| commit | d0db98fcd869605f28dc600bfeba032565e31855 (patch) | |
| tree | 53f5bf2a39d7c68972cb106bde9768375178fc63 /Python/bltinmodule.c | |
| parent | 956ffd75af881353fd59d61eb787df1512f0b59e (diff) | |
| download | cpython-git-d0db98fcd869605f28dc600bfeba032565e31855.tar.gz | |
#1688: On Windows, the input() prompt was not correctly displayed if it
contains non-ascii characters.
Reviewed by Benjamin Peterson.
Diffstat (limited to 'Python/bltinmodule.c')
| -rw-r--r-- | Python/bltinmodule.c | 21 | 
1 files changed, 19 insertions, 2 deletions
| diff --git a/Python/bltinmodule.c b/Python/bltinmodule.c index 7c08765b31..0b96dc1a1d 100644 --- a/Python/bltinmodule.c +++ b/Python/bltinmodule.c @@ -1597,12 +1597,29 @@ builtin_input(PyObject *self, PyObject *args)  		else  			Py_DECREF(tmp);  		if (promptarg != NULL) { -			po = PyObject_Str(promptarg); +			PyObject *stringpo; +			PyObject *stdout_encoding; +			stdout_encoding = PyObject_GetAttrString(fout, +								 "encoding"); +			if (stdout_encoding == NULL) { +				Py_DECREF(stdin_encoding); +				return NULL; +			} +			stringpo = PyObject_Str(promptarg); +			if (stringpo == NULL) { +				Py_DECREF(stdin_encoding); +				Py_DECREF(stdout_encoding); +				return NULL; +			} +			po = PyUnicode_AsEncodedString(stringpo, +				_PyUnicode_AsString(stdout_encoding), NULL); +			Py_DECREF(stdout_encoding); +			Py_DECREF(stringpo);  			if (po == NULL) {  				Py_DECREF(stdin_encoding);  				return NULL;  			} -			prompt = _PyUnicode_AsString(po); +			prompt = PyBytes_AsString(po);  			if (prompt == NULL) {  				Py_DECREF(stdin_encoding);  				Py_DECREF(po); | 
