summaryrefslogtreecommitdiff
path: root/morphlib/gitdir.py
diff options
context:
space:
mode:
authorSam Thursfield <sam.thursfield@codethink.co.uk>2014-11-06 16:31:34 +0000
committerSam Thursfield <sam.thursfield@codethink.co.uk>2014-11-06 16:31:34 +0000
commit6779e46e880eec757a6923441accef2442007677 (patch)
treead0dd5c28927cfcb5410760930b5bdfafaf5e948 /morphlib/gitdir.py
parenta04cb6cf9e3ad745af8b3c4d4675cfd4c3b12df1 (diff)
parent1a86803340081b9e929bb77491dfe01020516164 (diff)
downloadmorph-6779e46e880eec757a6923441accef2442007677.tar.gz
Merge branch 'sam/gitdir-fixes-v2'
Reviewed-By: Pedro Alvarez <pedro.alvarez@codethink.co.uk> Reviewed-By: Adam Coldrick <adam.coldrick@codethink.co.uk>
Diffstat (limited to 'morphlib/gitdir.py')
-rw-r--r--morphlib/gitdir.py37
1 files changed, 26 insertions, 11 deletions
diff --git a/morphlib/gitdir.py b/morphlib/gitdir.py
index fd7f3808..a0f35eef 100644
--- a/morphlib/gitdir.py
+++ b/morphlib/gitdir.py
@@ -343,21 +343,36 @@ class Remote(object):
class GitDirectory(object):
- '''Represent a git working tree + .git directory.
+ '''Represents a local Git repository.
- This class represents a directory that is the result of a
- "git clone". It includes both the .git subdirectory and
- the working tree. It is a thin abstraction, meant to make
- it easier to do certain git operations.
+ This class represents a directory that is the result of a `git clone` or
+ `git init`. It includes both the .git subdirectory and the working tree.
+ It is a thin abstraction, meant to make it easier to do certain git
+ operations.
+
+ In the case of bare repositories, there is no working tree. These are
+ supported, but a NoWorkingTree exception will be raised if you try to
+ perform any operations that require a working tree.
+
+ The repository must already exist on disk. Use gitdir.init() to create a
+ new repo, or gitdir.clone_from_cached_repo() if you want to clone a repo
+ that Morph has cached locally.
'''
- def __init__(self, dirname):
- self.dirname = morphlib.util.find_root(dirname, '.git')
- # if we are in a bare repo, self.dirname will now be None
- # so we just use the provided dirname
- if not self.dirname:
- self.dirname = dirname
+ def __init__(self, dirname, search_for_root=False):
+ '''Set up a GitDirectory instance for the repository at 'dirname'.
+
+ If 'search_for_root' is set to True, 'dirname' may point to a
+ subdirectory inside the working tree of repository. Otherwise 'dirname'
+ must be the top directory.
+
+ '''
+
+ if search_for_root:
+ dirname = morphlib.util.find_root(dirname, '.git')
+
+ self.dirname = dirname
self._config = {}
def _runcmd(self, argv, **kwargs):