summaryrefslogtreecommitdiff
authorJosh <jokajak@gmail.com>2012-03-19 01:30:36 (UTC)
committer Josh <jokajak@gmail.com>2012-03-19 01:30:36 (UTC)
commit67ba4cd7b5bc5e834db3106b3081677ee70d18f7 (patch) (side-by-side diff)
tree811b944f321218fdb3d9d02df13da2ea2eef4949
parent758bd68eee9c0ae1d3ad8dc50481c78557bd6228 (diff)
downloadclipperz-67ba4cd7b5bc5e834db3106b3081677ee70d18f7.zip
clipperz-67ba4cd7b5bc5e834db3106b3081677ee70d18f7.tar.gz
clipperz-67ba4cd7b5bc5e834db3106b3081677ee70d18f7.tar.bz2
add code to handle older version of GitPython
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--scripts/builder/repository.py11
1 files changed, 9 insertions, 2 deletions
diff --git a/scripts/builder/repository.py b/scripts/builder/repository.py
index 0045de7..a47e249 100644
--- a/scripts/builder/repository.py
+++ b/scripts/builder/repository.py
@@ -43,37 +43,44 @@ class Repository(object):
def version (self):
result = self.revision()
if self.areTherePendingChanges():
result = '>>> ' + result + ' <<<'
# print "VERSION: " + result
return result
#===================================================================
class GitRepository(Repository):
# http://gitorious.org/git-python
def revision (self):
- return self.repository.head.commit.hexsha
+ try:
+ return self.repository.head.commit.hexsha
+ except:
+ return self.repository.commits()[0].id
def areTherePendingChanges (self):
- return self.repository.is_dirty()
+ try:
+ return self.repository.is_dirty()
+ except TypeError, te:
+ return self.repository.is_dirty
+
#===================================================================
class HgRepository(Repository):
# http://mercurial.selenic.com/wiki/MercurialApi
def revision (self):
return 'hg:' + str(self.repository['tip'])
def areTherePendingChanges (self):
# TODO: FIXME: repository.status() does not report 'unknown(?)' files. :(
return not all(map(lambda fileList: len(fileList) == 0, self.repository.status()))