From 40e8246f6a5d659e09b27c4fc0803a0f99e5bb1c Mon Sep 17 00:00:00 2001 From: Barry Warsaw Date: Thu, 20 Nov 2008 20:14:50 +0000 Subject: Fix for bug 4362 "FileIO object in io module"; Patch by amaury.forgeotdarc. --- Lib/io.py | 26 ++++++++++++++++---------- 1 file changed, 16 insertions(+), 10 deletions(-) (limited to 'Lib/io.py') diff --git a/Lib/io.py b/Lib/io.py index 8e65a10e3a4..041e8ebd713 100644 --- a/Lib/io.py +++ b/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() -- cgit v1.2.3