# HG changeset patch # User Marcin Kuzminski # Date 2012-05-16 23:28:37 # Node ID 0ba23ea7912ac185acf1412b7999e3ad00a31e71 # Parent 533a126dc9ab51cb2876dd3adf07101f6ee1538a # Parent 982d8a80e048772dbc7ffd6cc112abec5301c9ff merge with beta diff --git a/rhodecode/controllers/files.py b/rhodecode/controllers/files.py --- a/rhodecode/controllers/files.py +++ b/rhodecode/controllers/files.py @@ -22,7 +22,7 @@ # # You should have received a copy of the GNU General Public License # along with this program. If not, see . - +from __future__ import with_statement import os import logging import traceback @@ -360,13 +360,14 @@ class FilesController(BaseRepoController except (ImproperArchiveTypeError, KeyError): return _('Unknown archive type') - archive = tempfile.NamedTemporaryFile(mode='w+r+b', delete=False) - cs.fill_archive(stream=archive, kind=fileformat, subrepos=subrepos) - archive.close() + fd, _archive_name = tempfile.mkstemp(suffix='rcarchive') + with open(_archive_name, 'wb') as f: + cs.fill_archive(stream=f, kind=fileformat, subrepos=subrepos) + response.content_type = content_type response.content_disposition = 'attachment; filename=%s-%s%s' \ % (repo_name, revision[:12], ext) - response.content_length = str(os.path.getsize(archive.name)) + response.content_length = str(os.path.getsize(_archive_name)) def get_chunked_archive(tmpfile): while True: @@ -376,7 +377,7 @@ class FilesController(BaseRepoController os.unlink(tmpfile.name) break yield data - return get_chunked_archive(tmpfile=open(archive.name,'rb')) + return get_chunked_archive(tmpfile=open(_archive_name, 'rb')) @HasRepoPermissionAnyDecorator('repository.read', 'repository.write', 'repository.admin')