From: Zac Medico Date: Thu, 8 May 2008 10:33:30 +0000 (-0000) Subject: Don't use try/finally to close atomic_ofstream since we don't want to X-Git-Tag: v2.2_pre7~68 X-Git-Url: http://git.tremily.us/?a=commitdiff_plain;h=c68ebc6b6f93d5a4bba5d9d6d3252cc686594ffa;p=portage.git Don't use try/finally to close atomic_ofstream since we don't want to call close() on this stream if an error occurs. svn path=/main/trunk/; revision=10231 --- diff --git a/pym/portage/dbapi/vartree.py b/pym/portage/dbapi/vartree.py index f433789cd..abc7916c8 100644 --- a/pym/portage/dbapi/vartree.py +++ b/pym/portage/dbapi/vartree.py @@ -2313,24 +2313,22 @@ class dblink(object): for filename in collisions: del blocker_contents[filename] f = atomic_ofstream(os.path.join(blocker.dbdir, "CONTENTS")) - try: - for filename in sorted(blocker_contents): - entry_data = blocker_contents[filename] - entry_type = entry_data[0] - relative_filename = filename[destroot_len:] - if entry_type == "obj": - entry_type, mtime, md5sum = entry_data - line = "%s %s %s %s\n" % \ - (entry_type, relative_filename, md5sum, mtime) - elif entry_type == "sym": - entry_type, mtime, link = entry_data - line = "%s %s -> %s %s\n" % \ - (entry_type, relative_filename, link, mtime) - else: # dir, dev, fif - line = "%s %s\n" % (entry_type, relative_filename) - f.write(line) - finally: - f.close() + for filename in sorted(blocker_contents): + entry_data = blocker_contents[filename] + entry_type = entry_data[0] + relative_filename = filename[destroot_len:] + if entry_type == "obj": + entry_type, mtime, md5sum = entry_data + line = "%s %s %s %s\n" % \ + (entry_type, relative_filename, md5sum, mtime) + elif entry_type == "sym": + entry_type, mtime, link = entry_data + line = "%s %s -> %s %s\n" % \ + (entry_type, relative_filename, link, mtime) + else: # dir, dev, fif + line = "%s %s\n" % (entry_type, relative_filename) + f.write(line) + f.close() # Due to mtime granularity, mtime checks do not always properly # invalidate vardbapi caches.