]> git.ipfire.org Git - thirdparty/Python/cpython.git/commitdiff
close files explicit (closes #21610)
authorBenjamin Peterson <benjamin@python.org>
Wed, 11 Mar 2015 00:06:18 +0000 (19:06 -0500)
committerBenjamin Peterson <benjamin@python.org>
Wed, 11 Mar 2015 00:06:18 +0000 (19:06 -0500)
Patch by mattip.

Lib/modulefinder.py

index f6f84f3fdea573f6ebd307f1a7ac21d1d3e28154..f16b2c7b5feb04e616f6c20fc73d7b6b234f3050 100644 (file)
@@ -109,16 +109,16 @@ class ModuleFinder:
 
     def run_script(self, pathname):
         self.msg(2, "run_script", pathname)
-        fp = open(pathname, READ_MODE)
-        stuff = ("", "r", imp.PY_SOURCE)
-        self.load_module('__main__', fp, pathname, stuff)
+        with open(pathname, READ_MODE) as fp:
+            stuff = ("", "r", imp.PY_SOURCE)
+            self.load_module('__main__', fp, pathname, stuff)
 
     def load_file(self, pathname):
         dir, name = os.path.split(pathname)
         name, ext = os.path.splitext(name)
-        fp = open(pathname, READ_MODE)
-        stuff = (ext, "r", imp.PY_SOURCE)
-        self.load_module(name, fp, pathname, stuff)
+        with open(pathname, READ_MODE) as fp:
+            stuff = (ext, "r", imp.PY_SOURCE)
+            self.load_module(name, fp, pathname, stuff)
 
     def import_hook(self, name, caller=None, fromlist=None, level=-1):
         self.msg(3, "import_hook", name, caller, fromlist, level)
@@ -461,6 +461,8 @@ class ModuleFinder:
         fp, buf, stuff = self.find_module("__init__", m.__path__)
         self.load_module(fqname, fp, buf, stuff)
         self.msgout(2, "load_package ->", m)
+        if fp:
+            fp.close()
         return m
 
     def add_module(self, fqname):