mirror of
				https://github.com/django/django.git
				synced 2025-10-25 22:56:12 +00:00 
			
		
		
		
	Fixed #8455: a lack of permissions in MEDIA_ROOT no longer causes an infinite loop when saving files. Thanks, carljm.
				
					
				
			git-svn-id: http://code.djangoproject.com/svn/django/trunk@8639 bcc190cf-cafb-0310-a4f2-bffc1f526a37
This commit is contained in:
		| @@ -1,4 +1,5 @@ | |||||||
| import os | import os | ||||||
|  | import errno | ||||||
| import urlparse | import urlparse | ||||||
|  |  | ||||||
| from django.conf import settings | from django.conf import settings | ||||||
| @@ -161,10 +162,13 @@ class FileSystemStorage(Storage): | |||||||
|                     finally: |                     finally: | ||||||
|                         locks.unlock(fd) |                         locks.unlock(fd) | ||||||
|                         os.close(fd) |                         os.close(fd) | ||||||
|             except OSError: |             except OSError, e: | ||||||
|                 # Ooops, we need a new file name. |                 if e.errno == errno.EEXIST: | ||||||
|  |                     # Ooops, the file exists. We need a new file name. | ||||||
|                     name = self.get_available_name(name) |                     name = self.get_available_name(name) | ||||||
|                     full_path = self.path(name) |                     full_path = self.path(name) | ||||||
|  |                 else: | ||||||
|  |                     raise | ||||||
|             else: |             else: | ||||||
|                 # OK, the file save worked. Break out of the loop. |                 # OK, the file save worked. Break out of the loop. | ||||||
|                 break |                 break | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user