]> rtime.felk.cvut.cz Git - notmuch.git/commitdiff
nmbug: Add an 'init' command
authorW. Trevor King <wking@tremily.us>
Tue, 28 Oct 2014 21:39:37 +0000 (14:39 -0700)
committerMichal Sojka <sojkam1@fel.cvut.cz>
Sat, 29 Nov 2014 09:09:53 +0000 (10:09 +0100)
For folks that want to start versioning a new tag-space, instead of
cloning one that someone else has already started.

The empty-blob hash-object call avoids errors like:

  $ nmbug commit
  error: invalid object 100644 e69de29bb2d1d6434b8b29ae775ad8c2e48c5391 for
'tags/...'
  fatal: git-write-tree: error building trees
  'git HASH(0x9ef3eb8) write-tree' exited with nonzero value

David Bremner suggested [1]:

  $ git hash-object -w /dev/null

instead of my Python version of:

  $ git hash-object -w --stdin <&-

but I expect that closing stdin is more portable than the /dev/null
path (which doesn't exist on Windows, for example).

[1]: id:87y4vu6uvf.fsf@maritornes.cs.unb.ca
     http://thread.gmane.org/gmane.mail.notmuch.general/18626/focus=18720

devel/nmbug/nmbug

index 9402eadecd7c733ef4fd31cd60c4ab5118462bbd..23bac5c048419e06d2b17d7113e21159165fb6ee 100755 (executable)
@@ -373,6 +373,29 @@ def fetch(remote=None):
     _git(args=args, wait=True)
 
 
+def init(remote=None):
+    """
+    Create an empty nmbug repository.
+
+    This wraps 'git init' with a few extra steps to support subsequent
+    status and commit commands.
+    """
+    with _tempfile.TemporaryDirectory(prefix='nmbug-init.') as workdir:
+        _spawn(
+            args=['git', 'init', '--separate-git-dir', NMBGIT, workdir],
+            wait=True)
+        _git(args=['config', '--unset', 'core.worktree'], wait=True)
+        _git(args=['config', 'core.bare', 'true'], wait=True)
+        # create an empty blob (e69de29bb2d1d6434b8b29ae775ad8c2e48c5391)
+        _git(args=['hash-object', '-w', '--stdin'], input='', wait=True)
+        _git(
+            args=[
+                'commit', '--allow-empty', '-m', 'Start a new nmbug repository'
+                ],
+            additional_env={'GIT_WORK_TREE': workdir},
+            wait=True)
+
+
 def checkout():
     """
     Update the notmuch database from Git.
@@ -703,6 +726,7 @@ if __name__ == '__main__':
             'clone',
             'commit',
             'fetch',
+            'init',
             'log',
             'merge',
             'pull',