]> granicus.if.org Git - python/commitdiff
Patch #443899: Check modes on files before performing operations.
authorMartin v. Löwis <martin@v.loewis.de>
Mon, 11 Mar 2002 06:46:52 +0000 (06:46 +0000)
committerMartin v. Löwis <martin@v.loewis.de>
Mon, 11 Mar 2002 06:46:52 +0000 (06:46 +0000)
Use IOErrors where file objects use them.

Lib/gzip.py

index 7f561532add527780f143e2b1d30a7cc1f48220f..74c0d26a065f7ce49bb10d73592e27cf08ca92b6 100644 (file)
@@ -61,7 +61,7 @@ class GzipFile:
                                              zlib.DEF_MEM_LEVEL,
                                              0)
         else:
-            raise ValueError, "Mode " + mode + " not supported"
+            raise IOError, "Mode " + mode + " not supported"
 
         self.fileobj = fileobj
         self.offset = 0
@@ -133,6 +133,10 @@ class GzipFile:
 
 
     def write(self,data):
+        if self.mode != WRITE:
+            import errno
+            raise IOError(errno.EBADF, "write() on read-only GzipFile object")
+        
         if self.fileobj is None:
             raise ValueError, "write() on closed GzipFile object"
         if len(data) > 0:
@@ -142,6 +146,10 @@ class GzipFile:
             self.offset += len(data)
 
     def read(self, size=-1):
+        if self.mode != READ:
+            import errno
+            raise IOError(errno.EBADF, "write() on read-only GzipFile object")
+            
         if self.extrasize <= 0 and self.fileobj is None:
             return ''