From a65efb0b622bc745bbeb1a8fa4f05b1b936a761b Mon Sep 17 00:00:00 2001 From: Aviv Keshet Date: Thu, 11 Apr 2013 17:51:34 -0700 Subject: [PATCH] refactor contents file writing to its own function This CL refactors out the functionality of writing a contents dicionary to file. That functionality is required by a change in the chromeos chromite repository. BUG=chromium:229234 TEST=None Change-Id: I851724408b1d10827eee2ea8d67bdca9ad90c455 --- pym/portage/dbapi/vartree.py | 23 +++++++++++++++++------ 1 file changed, 17 insertions(+), 6 deletions(-) diff --git a/pym/portage/dbapi/vartree.py b/pym/portage/dbapi/vartree.py index 9bc6e89b2..0d4a75608 100644 --- a/pym/portage/dbapi/vartree.py +++ b/pym/portage/dbapi/vartree.py @@ -1010,12 +1010,23 @@ class vardbapi(dbapi): removed += 1 if removed: - self._bump_mtime(pkg.mycpv) - f = atomic_ofstream(os.path.join(pkg.dbdir, "CONTENTS")) - write_contents(new_contents, root, f) - f.close() - self._bump_mtime(pkg.mycpv) - pkg._clear_contents_cache() + self.writeContentsToContentsFile(pkg, new_contents) + + def writeContentsToContentsFile(self, pkg, new_contents): + """ + @param pkg: package to write contents file for + @type pkg: dblink + @param new_contents: contents to write to CONTENTS file + @type new_contents: contents dictionary of the form + {u'/path/to/file' : (contents_attribute 1, ...), ...} + """ + root = self.settings['ROOT'] + self._bump_mtime(pkg.mycpv) + f = atomic_ofstream(os.path.join(pkg.dbdir, "CONTENTS")) + write_contents(new_contents, root, f) + f.close() + self._bump_mtime(pkg.mycpv) + pkg._clear_contents_cache() class _owners_cache(object): """ -- 2.26.2