]> granicus.if.org Git - python/commitdiff
Issue #15068: Avoid creating a reference loop in fileinput.
authorSerhiy Storchaka <storchaka@gmail.com>
Tue, 8 Mar 2016 21:35:35 +0000 (23:35 +0200)
committerSerhiy Storchaka <storchaka@gmail.com>
Tue, 8 Mar 2016 21:35:35 +0000 (23:35 +0200)
Lib/fileinput.py

index 9f14762db032cb14422a98bc4f8a7717faf2f557..d2b52066d920f6d45c14937a237360d4be9a3a93 100644 (file)
@@ -207,7 +207,6 @@ class FileInput:
         self._startlineno = 0
         self._filelineno = 0
         self._file = None
-        self._readline = self._start_readline
         self._isstdin = False
         self._backupfilename = None
         # restrict mode argument to reading modes
@@ -245,15 +244,15 @@ class FileInput:
         return self
 
     def __next__(self):
-        line = self._readline()
-        if line:
-            self._filelineno += 1
-            return line
-        if not self._file:
-            raise StopIteration
-        self.nextfile()
-        # Recursive call
-        return self.__next__()
+        while True:
+            line = self._readline()
+            if line:
+                self._filelineno += 1
+                return line
+            if not self._file:
+                raise StopIteration
+            self.nextfile()
+            # repeat with next file
 
     def __getitem__(self, i):
         if i != self.lineno():
@@ -277,7 +276,10 @@ class FileInput:
         finally:
             file = self._file
             self._file = None
-            self._readline = self._start_readline
+            try:
+                del self._readline  # restore FileInput._readline
+            except AttributeError:
+                pass
             try:
                 if file and not self._isstdin:
                     file.close()
@@ -301,7 +303,7 @@ class FileInput:
             self.nextfile()
             # repeat with next file
 
-    def _start_readline(self):
+    def _readline(self):
         if not self._files:
             if 'b' in self._mode:
                 return b''
@@ -356,7 +358,7 @@ class FileInput:
                     self._file = self._openhook(self._filename, self._mode)
                 else:
                     self._file = open(self._filename, self._mode)
-        self._readline = self._file.readline
+        self._readline = self._file.readline  # hide FileInput._readline
         return self._readline()
 
     def filename(self):