summaryrefslogtreecommitdiff
authorJosh <jokajak@gmail.com>2012-03-06 15:44:48 (UTC)
committer Josh <jokajak@gmail.com>2012-03-06 15:44:48 (UTC)
commit5115ce2faf3efdf2bec242d9c37d0524bf341a94 (patch) (unidiff)
treedc0a49441a2f473c8614d95f27c5e391334e7a6f
parentba9eff02a0ee404e9da1431e8ab6056b3f3b97f5 (diff)
downloadclipperz-5115ce2faf3efdf2bec242d9c37d0524bf341a94.zip
clipperz-5115ce2faf3efdf2bec242d9c37d0524bf341a94.tar.gz
clipperz-5115ce2faf3efdf2bec242d9c37d0524bf341a94.tar.bz2
Check to make sure dulwich is available and print error
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--scripts/builder/repository.py2
1 files changed, 2 insertions, 0 deletions
diff --git a/scripts/builder/repository.py b/scripts/builder/repository.py
index 89db9a5..f3f7d6f 100644
--- a/scripts/builder/repository.py
+++ b/scripts/builder/repository.py
@@ -1,58 +1,60 @@
1#!/usr/bin/env python 1#!/usr/bin/env python
2# -*- coding: UTF-8 -*- 2# -*- coding: UTF-8 -*-
3 3
4 4
5def repositoryWithPath (path): 5def repositoryWithPath (path):
6 try: 6 try:
7 from dulwich.repo import Repo 7 from dulwich.repo import Repo
8 8
9 repo = Repo(path) 9 repo = Repo(path)
10 result = GitRepository(repo, path) 10 result = GitRepository(repo, path)
11 except ImportError:
12 print "Failed to import dulwich, please install http://www.samba.org/~jelmer/dulwich/"
11 except: 13 except:
12 from mercurial import ui, hg 14 from mercurial import ui, hg
13 15
14 repo = hg.repository(ui.ui(), path) 16 repo = hg.repository(ui.ui(), path)
15 result = HgRepository(repo, path) 17 result = HgRepository(repo, path)
16 18
17 return result 19 return result
18 20
19 21
20#=================================================================== 22#===================================================================
21 23
22 24
23class Repository(object): 25class Repository(object):
24 26
25 def __init__ (self, repository, path): 27 def __init__ (self, repository, path):
26 self.repository = repository 28 self.repository = repository
27 self.path = path 29 self.path = path
28 30
29 31
30 def revision (self): 32 def revision (self):
31 raise NotImplementedError() 33 raise NotImplementedError()
32 34
33 35
34 def areTherePendingChanges (self): 36 def areTherePendingChanges (self):
35 raise NotImplementedError() 37 raise NotImplementedError()
36 38
37 39
38 def version (self): 40 def version (self):
39 result = self.revision() 41 result = self.revision()
40 if self.areTherePendingChanges(): 42 if self.areTherePendingChanges():
41 result = '>>> ' + result + ' <<<' 43 result = '>>> ' + result + ' <<<'
42 44
43 # print "VERSION: " + result 45 # print "VERSION: " + result
44 return result 46 return result
45 47
46 48
47#=================================================================== 49#===================================================================
48 50
49 51
50class GitRepository(Repository): 52class GitRepository(Repository):
51 53
52 def revision (self): 54 def revision (self):
53 return repository.refs['HEAD'] 55 return repository.refs['HEAD']
54 56
55 57
56 def areTherePendingChanges (self): 58 def areTherePendingChanges (self):
57 return repository.is_dirty() 59 return repository.is_dirty()
58 60