Only catch the errors that can actually occur, as reported in bug #411881.
authorMartin v. Löwis <martin@v.loewis.de>
Sat, 11 Aug 2001 15:02:57 +0000 (15:02 +0000)
committerMartin v. Löwis <martin@v.loewis.de>
Sat, 11 Aug 2001 15:02:57 +0000 (15:02 +0000)
Lib/types.py
Lib/urllib.py

index 742b8cc5ff4d86d527cd5bb5fb41e43f76f80781..01af46364013ab6785bd0f4151f448cd09ddd058 100644 (file)
@@ -31,7 +31,8 @@ FunctionType = type(_f)
 LambdaType = type(lambda: None)         # Same as FunctionType
 try:
     CodeType = type(_f.func_code)
-except:
+except RuntimeError:
+    # Execution in restricted environment
     pass
 
 def g():
@@ -54,7 +55,8 @@ ModuleType = type(sys)
 
 try:
     FileType = type(sys.__stdin__)
-except:
+except AttributeError:
+    # Not available in restricted mode
     pass
 XRangeType = type(xrange(0))
 
@@ -65,7 +67,9 @@ except TypeError:
         tb = sys.exc_info()[2]
         TracebackType = type(tb)
         FrameType = type(tb.tb_frame)
-    except:
+    except AttributeError:
+        # In the restricted environment, exc_info returns (None, None,
+        # None) Then, tb.tb_frame gives an attribute error
         pass
     tb = None; del tb
 
index 82b5fb9a93d95cf09912da5e8415deb5ac000eb2..f60a84154af47566301eb5b07512b3c2a3009d66 100644 (file)
@@ -134,7 +134,7 @@ class URLopener:
             for file in self.__tempfiles:
                 try:
                     self.__unlink(file)
-                except:
+                except OSError:
                     pass
             del self.__tempfiles[:]
         if self.tempcache:
@@ -1069,7 +1069,7 @@ def unquote(s):
             try:
                 myappend(mychr(myatoi(item[:2], 16))
                      + item[2:])
-            except:
+            except ValueError:
                 myappend('%' + item)
         else:
             myappend('%' + item)