commit:     9132fdaedfcb8aac0cebdc4154120fbf45b04a42
Author:     Brian Dolbec <dolsen <AT> gentoo <DOT> org>
AuthorDate: Mon Jun 16 17:58:09 2014 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Mon Oct 20 03:48:34 2014 +0000
URL:        
http://sources.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=9132fdae

sync/modules/svn: Add snv upgrade to sync operation

This prevents errors when a newer svn has been installed that requires a db 
upgrade.

---
 pym/portage/sync/modules/svn/svn.py | 23 +++++++++++++++++++++++
 1 file changed, 23 insertions(+)

diff --git a/pym/portage/sync/modules/svn/svn.py 
b/pym/portage/sync/modules/svn/svn.py
index 182a7ac..0365e90 100644
--- a/pym/portage/sync/modules/svn/svn.py
+++ b/pym/portage/sync/modules/svn/svn.py
@@ -62,6 +62,10 @@ class SVNSync(SyncBase):
                @rtype: (int, bool)
                """
 
+               exitcode, d = self._svn_upgrade()
+               if exitcode != os.EX_OK:
+                       return (exitcode, False)
+
                svn_root = self.repo.sync_uri
 
                if svn_root.startswith("svn://"):
@@ -79,3 +83,22 @@ class SVNSync(SyncBase):
                                self.logger(self.xterm_titles, msg)
                                writemsg_level(msg + "\n", noiselevel=-1, 
level=logging.ERROR)
                return (exitcode, False)
+
+
+       def _svn_upgrade(self):
+               """
+               Internal function which performs an svn upgrade on the repo
+
+               @return: tuple of return code (0=success), whether the cache
+                       needs to be updated
+               @rtype: (int, bool)
+               """
+               exitcode = portage.process.spawn_bash(
+                       "cd %s; exec svn upgrade" %
+                       (portage._shell_quote(self.repo.location),),
+                       **portage._native_kwargs(self.spawn_kwargs))
+               if exitcode != os.EX_OK:
+                       msg = "!!! svn upgrade error; exiting."
+                       self.logger(self.xterm_titles, msg)
+                       writemsg_level(msg + "\n", noiselevel=-1, 
level=logging.ERROR)
+               return (exitcode, False)

Reply via email to