summary refs log tree commit diff stats
path: root/ranger/vcs/bzr.py
diff options
context:
space:
mode:
authorAbdo Roig-Maranges <abdo.roig@gmail.com>2013-02-13 10:46:54 +0100
committerhut <hut@lavabit.com>2013-02-15 22:40:10 +0100
commitca93ee5a9c54e3802726d09becdab745a41cc4ba (patch)
tree2072195ae90cccfa67d00b6eacf93e6191086623 /ranger/vcs/bzr.py
parentaff0fa07a88d2e532420b69b244c332c5e6d7e08 (diff)
downloadranger-ca93ee5a9c54e3802726d09becdab745a41cc4ba.tar.gz
fix vcs log errors on empty repos
Diffstat (limited to 'ranger/vcs/bzr.py')
-rw-r--r--ranger/vcs/bzr.py20
1 files changed, 18 insertions, 2 deletions
diff --git a/ranger/vcs/bzr.py b/ranger/vcs/bzr.py
index 2bd0c27a..a63eea54 100644
--- a/ranger/vcs/bzr.py
+++ b/ranger/vcs/bzr.py
@@ -36,6 +36,12 @@ class Bzr(Vcs):
         return self._vcs(path, 'bzr', args, silent=silent, catchout=catchout, bytes=bytes)
 
 
+    def _has_head(self):
+        """Checks whether repo has head"""
+        rnum = self._bzr(self.path, ['revno'], catchout=True)
+        return rnum != '0'
+
+
     def _sanitize_rev(self, rev):
         if rev == None: return None
         rev = rev.strip()
@@ -203,11 +209,13 @@ class Bzr(Vcs):
 
     def get_log(self, filelist=None, maxres=None):
         """Get the entire log for the current HEAD"""
+        if not self._has_head(): return []
         return self._log(refspec=None, filelist=filelist)
 
 
     def get_raw_log(self, filelist=None):
         """Gets the raw log as a string"""
+        if not self._has_head(): return []
         args = ['log']
         if filelist: args = args + filelist
         return self._bzr(self.path, args, catchout=True)
@@ -223,7 +231,11 @@ class Bzr(Vcs):
 
     def get_remote(self):
         """Returns the url for the remote repo attached to head"""
-        remote = self._bzr(self.path, ['config', 'parent_location'], catchout=True)
+        try:
+            remote = self._bzr(self.path, ['config', 'parent_location'], catchout=True)
+        except VcsError:
+            remote = ""
+
         return remote.strip() or None
 
 
@@ -232,7 +244,10 @@ class Bzr(Vcs):
         if rev == None: rev = self.HEAD
         elif rev == self.INDEX: return None
         rev = self._sanitize_rev(rev)
-        L = self._log(refspec=rev)
+        try:
+            L = self._log(refspec=rev)
+        except VcsError:
+            L = []
         if len(L) == 0: return None
         else:           return L[0]['revid']
 
@@ -241,6 +256,7 @@ class Bzr(Vcs):
         """Gets info about the given revision rev"""
         if rev == None: rev = self.HEAD
         rev = self._sanitize_rev(rev)
+        if rev == self.HEAD and not self._has_head(): return []
 
         L = self._log(refspec=rev)
         if len(L) == 0: