mirror of
https://github.com/python/cpython.git
synced 2025-08-22 09:45:06 +00:00
Fix for bug 4362 "FileIO object in io module"; Patch by amaury.forgeotdarc.
This commit is contained in:
parent
91cc8fb92b
commit
40e8246f6a
2 changed files with 47 additions and 10 deletions
26
Lib/io.py
26
Lib/io.py
|
@ -239,8 +239,6 @@ def open(file, mode="r", buffering=None, encoding=None, errors=None,
|
|||
raise ValueError("invalid buffering size")
|
||||
if buffering == 0:
|
||||
if binary:
|
||||
raw._name = file
|
||||
raw._mode = mode
|
||||
return raw
|
||||
raise ValueError("can't have unbuffered text I/O")
|
||||
if updating:
|
||||
|
@ -252,11 +250,8 @@ def open(file, mode="r", buffering=None, encoding=None, errors=None,
|
|||
else:
|
||||
raise ValueError("unknown mode: %r" % mode)
|
||||
if binary:
|
||||
buffer.name = file
|
||||
buffer.mode = mode
|
||||
return buffer
|
||||
text = TextIOWrapper(buffer, encoding, errors, newline, line_buffering)
|
||||
text.name = file
|
||||
text.mode = mode
|
||||
return text
|
||||
|
||||
|
@ -616,6 +611,10 @@ class FileIO(_fileio._FileIO, RawIOBase):
|
|||
# that _fileio._FileIO inherits from io.RawIOBase (which would be hard
|
||||
# to do since _fileio.c is written in C).
|
||||
|
||||
def __init__(self, name, mode="r", closefd=True):
|
||||
_fileio._FileIO.__init__(self, name, mode, closefd)
|
||||
self._name = name
|
||||
|
||||
def close(self):
|
||||
_fileio._FileIO.close(self)
|
||||
RawIOBase.close(self)
|
||||
|
@ -624,11 +623,6 @@ class FileIO(_fileio._FileIO, RawIOBase):
|
|||
def name(self):
|
||||
return self._name
|
||||
|
||||
# XXX(gb): _FileIO already has a mode property
|
||||
@property
|
||||
def mode(self):
|
||||
return self._mode
|
||||
|
||||
|
||||
class BufferedIOBase(IOBase):
|
||||
|
||||
|
@ -762,6 +756,14 @@ class _BufferedIOMixin(BufferedIOBase):
|
|||
def closed(self):
|
||||
return self.raw.closed
|
||||
|
||||
@property
|
||||
def name(self):
|
||||
return self.raw.name
|
||||
|
||||
@property
|
||||
def mode(self):
|
||||
return self.raw.mode
|
||||
|
||||
### Lower-level APIs ###
|
||||
|
||||
def fileno(self):
|
||||
|
@ -1464,6 +1466,10 @@ class TextIOWrapper(TextIOBase):
|
|||
def closed(self):
|
||||
return self.buffer.closed
|
||||
|
||||
@property
|
||||
def name(self):
|
||||
return self.buffer.name
|
||||
|
||||
def fileno(self):
|
||||
return self.buffer.fileno()
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue