Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
C
cpython
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Kirill Smelkov
cpython
Commits
9e284c00
Commit
9e284c00
authored
Apr 14, 2014
by
Benjamin Peterson
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
when an exception is raised in fdopen, never close the fd (changing on my mind on #21191)
parent
f94f11ba
Changes
4
Hide whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
30 additions
and
17 deletions
+30
-17
Doc/library/os.rst
Doc/library/os.rst
+1
-1
Lib/test/test_posix.py
Lib/test/test_posix.py
+1
-1
Misc/NEWS
Misc/NEWS
+1
-1
Modules/posixmodule.c
Modules/posixmodule.c
+27
-14
No files found.
Doc/library/os.rst
View file @
9e284c00
...
...
@@ -465,7 +465,7 @@ These functions create new file objects. (See also :func:`open`.)
Return an open file object connected to the file descriptor *fd*. The *mode*
and *bufsize* arguments have the same meaning as the corresponding arguments
to the built-in :func:`open` function. If :func:`fdopen` raises an
exception, it
closes *fd*
.
exception, it
leaves *fd* untouched (unclosed)
.
Availability: Unix, Windows.
...
...
Lib/test/test_posix.py
View file @
9e284c00
...
...
@@ -196,7 +196,7 @@ class PosixTester(unittest.TestCase):
fd
=
os
.
open
(
test_support
.
TESTFN
,
os
.
O_RDONLY
)
self
.
assertRaises
(
OSError
,
posix
.
fdopen
,
fd
,
'w'
)
self
.
assertRaises
(
OSError
,
os
.
close
,
fd
)
# fd should
be closed.
os
.
close
(
fd
)
# fd should not
be closed.
@
unittest
.
skipUnless
(
hasattr
(
posix
,
'O_EXLOCK'
),
'test needs posix.O_EXLOCK'
)
...
...
Misc/NEWS
View file @
9e284c00
...
...
@@ -51,7 +51,7 @@ Library
-
Issue
#
21172
:
isinstance
check
relaxed
from
dict
to
collections
.
Mapping
.
-
Issue
#
21191
:
In
os
.
fdopen
,
alwyas
close
the
file
descriptor
when
an
exception
-
Issue
#
21191
:
In
os
.
fdopen
,
never
close
the
file
descriptor
when
an
exception
happens
.
-
Issue
#
21149
:
Improved
thread
-
safety
in
logging
cleanup
during
interpreter
...
...
Modules/posixmodule.c
View file @
9e284c00
...
...
@@ -6841,19 +6841,37 @@ posix_fdopen(PyObject *self, PyObject *args)
/* Sanitize mode. See fileobject.c */
mode
=
PyMem_MALLOC
(
strlen
(
orgmode
)
+
3
);
if
(
!
mode
)
{
close
(
fd
);
PyErr_NoMemory
();
return
NULL
;
}
strcpy
(
mode
,
orgmode
);
if
(
_PyFile_SanitizeMode
(
mode
))
{
close
(
fd
);
PyMem_FREE
(
mode
);
return
NULL
;
}
if
(
!
_PyVerify_fd
(
fd
))
{
posix_error
();
close
(
fd
);
PyMem_FREE
(
mode
);
return
posix_error
();
}
#if defined(HAVE_FSTAT) && defined(S_IFDIR) && defined(EISDIR)
{
struct
stat
buf
;
if
(
fstat
(
fd
,
&
buf
)
==
0
&&
S_ISDIR
(
buf
.
st_mode
))
{
PyMem_FREE
(
mode
);
char
*
msg
=
strerror
(
EISDIR
);
PyObject
*
exc
=
PyObject_CallFunction
(
PyExc_IOError
,
"(isO)"
,
EISDIR
,
msg
,
"<fdopen>"
);
PyErr_SetObject
(
PyExc_IOError
,
exc
);
Py_XDECREF
(
exc
);
return
NULL
;
}
}
#endif
/* The dummy filename used here must be kept in sync with the value
tested against in gzip.GzipFile.__init__() - see issue #13781. */
f
=
PyFile_FromFile
(
NULL
,
"<fdopen>"
,
orgmode
,
fclose
);
if
(
f
==
NULL
)
{
PyMem_FREE
(
mode
);
return
NULL
;
}
Py_BEGIN_ALLOW_THREADS
...
...
@@ -6876,16 +6894,11 @@ posix_fdopen(PyObject *self, PyObject *args)
#endif
Py_END_ALLOW_THREADS
PyMem_FREE
(
mode
);
if
(
fp
==
NULL
)
{
posix_error
();
close
(
fd
);
return
NULL
;
}
/* The dummy filename used here must be kept in sync with the value
tested against in gzip.GzipFile.__init__() - see issue #13781. */
f
=
PyFile_FromFile
(
fp
,
"<fdopen>"
,
orgmode
,
fclose
);
if
(
f
!=
NULL
)
PyFile_SetBufSize
(
f
,
bufsize
);
if
(
fp
==
NULL
)
return
posix_error
();
/* We now know we will succeed, so initialize the file object. */
((
PyFileObject
*
)
f
)
->
f_fp
=
fp
;
PyFile_SetBufSize
(
f
,
bufsize
);
return
f
;
}
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment