summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorVictor Stinner <victor.stinner@gmail.com>2015-04-24 22:21:52 (GMT)
committerVictor Stinner <victor.stinner@gmail.com>2015-04-24 22:21:52 (GMT)
commitcc0bbbc781254cc43628649815435ababafa35e2 (patch)
tree30d66f42f696052e68a45ada7696b93c29361fd7
parent51f58059f6d5eb958201d1d90286e5917b77ed59 (diff)
parent4403d7def0ec8e6b395223fb2ab8b570ecc7a6e4 (diff)
downloadcpython-cc0bbbc781254cc43628649815435ababafa35e2.zip
cpython-cc0bbbc781254cc43628649815435ababafa35e2.tar.gz
cpython-cc0bbbc781254cc43628649815435ababafa35e2.tar.bz2
(Merge 3.4) Issue #9246: On POSIX, os.getcwd() now supports paths longer than
1025 bytes. Patch written by William Orr.
-rw-r--r--Misc/NEWS5
-rw-r--r--Modules/posixmodule.c36
2 files changed, 32 insertions, 9 deletions
diff --git a/Misc/NEWS b/Misc/NEWS
index 4f702d0..c559ea5 100644
--- a/Misc/NEWS
+++ b/Misc/NEWS
@@ -15,6 +15,9 @@ Core and Builtins
Library
-------
+- Issue #9246: On POSIX, os.getcwd() now supports paths longer than 1025 bytes.
+ Patch written by William Orr.
+
- Issue #17445: add difflib.diff_bytes() to support comparison of
byte strings (fixes a regression from Python 2).
@@ -33,7 +36,7 @@ Library
- Issue #23728: binascii.crc_hqx() could return an integer outside of the range
0-0xffff for empty data.
-- Issue #23887: urllib.error.HTTPError now has a proper repr() representation.
+- Issue #23887: urllib.error.HTTPError now has a proper repr() representation.
Patch by Berker Peksag.
Documentation
diff --git a/Modules/posixmodule.c b/Modules/posixmodule.c
index ce34b3b..3bed958 100644
--- a/Modules/posixmodule.c
+++ b/Modules/posixmodule.c
@@ -3267,12 +3267,15 @@ os_lchown_impl(PyModuleDef *module, path_t *path, uid_t uid, gid_t gid)
static PyObject *
posix_getcwd(int use_bytes)
{
- char buf[1026];
- char *res;
+ char *buf, *tmpbuf;
+ char *cwd;
+ const size_t chunk = 1024;
+ size_t buflen = 0;
+ PyObject *obj;
#ifdef MS_WINDOWS
if (!use_bytes) {
- wchar_t wbuf[1026];
+ wchar_t wbuf[MAXPATHLEN];
wchar_t *wbuf2 = wbuf;
PyObject *resobj;
DWORD len;
@@ -3306,14 +3309,31 @@ posix_getcwd(int use_bytes)
return NULL;
#endif
+ buf = cwd = NULL;
Py_BEGIN_ALLOW_THREADS
- res = getcwd(buf, sizeof buf);
+ do {
+ buflen += chunk;
+ tmpbuf = PyMem_RawRealloc(buf, buflen);
+ if (tmpbuf == NULL)
+ break;
+
+ buf = tmpbuf;
+ cwd = getcwd(buf, buflen);
+ } while (cwd == NULL && errno == ERANGE);
Py_END_ALLOW_THREADS
- if (res == NULL)
+
+ if (cwd == NULL) {
+ PyMem_RawFree(buf);
return posix_error();
+ }
+
if (use_bytes)
- return PyBytes_FromStringAndSize(buf, strlen(buf));
- return PyUnicode_DecodeFSDefault(buf);
+ obj = PyBytes_FromStringAndSize(buf, strlen(buf));
+ else
+ obj = PyUnicode_DecodeFSDefault(buf);
+ PyMem_RawFree(buf);
+
+ return obj;
}
@@ -8873,7 +8893,7 @@ os_truncate_impl(PyModuleDef *module, path_t *path, Py_off_t length)
fd = _wopen(path->wide, _O_WRONLY | _O_BINARY | _O_NOINHERIT);
else
fd = _open(path->narrow, _O_WRONLY | _O_BINARY | _O_NOINHERIT);
- if (fd < 0)
+ if (fd < 0)
result = -1;
else {
result = _chsize_s(fd, length);