Re: [PATCH 4/4] nmbug: Add an 'init' command
authorDavid Edmondson <dme@dme.org>
Mon, 15 Sep 2014 16:13:50 +0000 (17:13 +0100)
committerW. Trevor King <wking@tremily.us>
Fri, 7 Nov 2014 18:04:32 +0000 (10:04 -0800)
4f/ba542c17076e8fe4733e07aa2657b1f09149a0 [new file with mode: 0644]

diff --git a/4f/ba542c17076e8fe4733e07aa2657b1f09149a0 b/4f/ba542c17076e8fe4733e07aa2657b1f09149a0
new file mode 100644 (file)
index 0000000..62aeac1
--- /dev/null
@@ -0,0 +1,135 @@
+Return-Path: <dme@dme.org>\r
+X-Original-To: notmuch@notmuchmail.org\r
+Delivered-To: notmuch@notmuchmail.org\r
+Received: from localhost (localhost [127.0.0.1])\r
+       by olra.theworths.org (Postfix) with ESMTP id 09A90431FBC\r
+       for <notmuch@notmuchmail.org>; Mon, 15 Sep 2014 09:14:05 -0700 (PDT)\r
+X-Virus-Scanned: Debian amavisd-new at olra.theworths.org\r
+X-Spam-Flag: NO\r
+X-Spam-Score: -0.7\r
+X-Spam-Level: \r
+X-Spam-Status: No, score=-0.7 tagged_above=-999 required=5\r
+       tests=[RCVD_IN_DNSWL_LOW=-0.7] autolearn=disabled\r
+Received: from olra.theworths.org ([127.0.0.1])\r
+       by localhost (olra.theworths.org [127.0.0.1]) (amavisd-new, port 10024)\r
+       with ESMTP id 93NJNUrzEy-7 for <notmuch@notmuchmail.org>;\r
+       Mon, 15 Sep 2014 09:14:00 -0700 (PDT)\r
+Received: from mail-wi0-f173.google.com (mail-wi0-f173.google.com\r
+       [209.85.212.173]) (using TLSv1 with cipher RC4-SHA (128/128 bits))\r
+       (No client certificate requested)\r
+       by olra.theworths.org (Postfix) with ESMTPS id 17B6E431FAE\r
+       for <notmuch@notmuchmail.org>; Mon, 15 Sep 2014 09:13:59 -0700 (PDT)\r
+Received: by mail-wi0-f173.google.com with SMTP id em10so4562877wid.6\r
+       for <notmuch@notmuchmail.org>; Mon, 15 Sep 2014 09:13:56 -0700 (PDT)\r
+X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed;\r
+       d=1e100.net; s=20130820;\r
+       h=x-gm-message-state:to:cc:subject:in-reply-to:references:user-agent\r
+       :from:date:message-id:mime-version:content-type;\r
+       bh=lrKsq60AuHwUP2nf8KsYyzBZPIbtAmEx1MyZZxr4YCo=;\r
+       b=H9te+FLeOSJ2ovGFd3r1/oRwzl1gurjHuE+doxJt0oNkb3O51IVYbPIcJyrBPUg0WR\r
+       VyP8jdazdgfsSrSLZib8ynVRNeZKRxfD8sy65vvX3wp0MmizWAnkq+cr997fPzFQdKVP\r
+       fa7shlHnaIW3gmMKY3GnJpZ66Yik4rQ5XOSoLEqRTERwxHHYjJ86vXTkCcxirEZ/IdTh\r
+       NkIko0J7JWMWUXdXQSQ32ZdAXYkfkKBEXVuvAbAhqvDitiQa2nREReebs0QHgePV+Vap\r
+       PtgCLl50gFKQln4ZrKt/D+roHaps8UbRwq2jIAzF0zFjMRIuRRpCs40MRODet7P8NM3Z\r
+       Rdww==\r
+X-Gm-Message-State:\r
+ ALoCoQnv0r4VNagy5ulr3La7ZiYlmMU5akXT5TPWKnUkiqXG/6vJiuqFV/JxcHygQI8C6ui0iHVY\r
+X-Received: by 10.194.186.178 with SMTP id fl18mr34632411wjc.8.1410797634993; \r
+       Mon, 15 Sep 2014 09:13:54 -0700 (PDT)\r
+Received: from localhost ([2a01:348:1a2:1:f00a:9c2f:b998:3319])\r
+       by mx.google.com with ESMTPSA id\r
+       hi4sm15253016wjb.46.2014.09.15.09.13.54 for <multiple recipients>\r
+       (version=TLSv1.2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128);\r
+       Mon, 15 Sep 2014 09:13:54 -0700 (PDT)\r
+To: "W. Trevor King" <wking@tremily.us>, notmuch@notmuchmail.org\r
+Subject: Re: [PATCH 4/4] nmbug: Add an 'init' command\r
+In-Reply-To:\r
+ <05ccd672f55444f74da62250e2305fb84fdc6c42.1404678709.git.wking@tremily.us>\r
+References: <cover.1404678709.git.wking@tremily.us>\r
+       <05ccd672f55444f74da62250e2305fb84fdc6c42.1404678709.git.wking@tremily.us>\r
+User-Agent: Notmuch/0.18.1 (http://notmuchmail.org) Emacs/24.3.1\r
+       (x86_64-apple-darwin)\r
+From: David Edmondson <dme@dme.org>\r
+Date: Mon, 15 Sep 2014 17:13:50 +0100\r
+Message-ID: <m2zje0kgjl.fsf@fenchurch.hh.sledj.net>\r
+MIME-Version: 1.0\r
+Content-Type: text/plain\r
+Cc: David Bremner <bremner@debian.org>\r
+X-BeenThere: notmuch@notmuchmail.org\r
+X-Mailman-Version: 2.1.13\r
+Precedence: list\r
+List-Id: "Use and development of the notmuch mail system."\r
+       <notmuch.notmuchmail.org>\r
+List-Unsubscribe: <http://notmuchmail.org/mailman/options/notmuch>,\r
+       <mailto:notmuch-request@notmuchmail.org?subject=unsubscribe>\r
+List-Archive: <http://notmuchmail.org/pipermail/notmuch>\r
+List-Post: <mailto:notmuch@notmuchmail.org>\r
+List-Help: <mailto:notmuch-request@notmuchmail.org?subject=help>\r
+List-Subscribe: <http://notmuchmail.org/mailman/listinfo/notmuch>,\r
+       <mailto:notmuch-request@notmuchmail.org?subject=subscribe>\r
+X-List-Received-Date: Mon, 15 Sep 2014 16:14:05 -0000\r
+\r
+On Sun, Jul 06 2014, W. Trevor King wrote:\r
+> For folks that want to start versioning a new tag-space, instead of\r
+> cloning one that someone else has already started.\r
+\r
+I tried this patch, and it (appeared) to work for me. Given that the\r
+procedure for creating a new tag repository is arcane, could this patch\r
+(or a version of it) be pushed?\r
+\r
+> The empty-blob hash-object call avoids errors like:\r
+>\r
+>   $ nmbug commit\r
+>   error: invalid object 100644 e69de29bb2d1d6434b8b29ae775ad8c2e48c5391 for 'tags/...'\r
+>   fatal: git-write-tree: error building trees\r
+>   'git HASH(0x9ef3eb8) write-tree' exited with nonzero value\r
+> ---\r
+>  devel/nmbug/nmbug | 19 +++++++++++++++++++\r
+>  1 file changed, 19 insertions(+)\r
+>\r
+> diff --git a/devel/nmbug/nmbug b/devel/nmbug/nmbug\r
+> index c9ac046..b64dab9 100755\r
+> --- a/devel/nmbug/nmbug\r
+> +++ b/devel/nmbug/nmbug\r
+> @@ -30,6 +30,7 @@ my %command = (\r
+>           commit     => \&do_commit,\r
+>           fetch      => \&do_fetch,\r
+>           help       => \&do_help,\r
+> +         init       => \&do_init,\r
+>           log        => \&do_log,\r
+>           merge      => \&do_merge,\r
+>           pull       => \&do_pull,\r
+> @@ -152,6 +153,18 @@ sub do_clone {\r
+>    git ('config', 'core.bare', 'true');\r
+>  }\r
+>  \r
+> +sub do_init {\r
+> +  my $tempwork = tempdir ('/tmp/nmbug-init.XXXXXX', CLEANUP => 1);\r
+> +  system ('git', 'init', '--separate-git-dir', $NMBGIT, $tempwork) == 0\r
+> +    or die "'git init' exited with nonzero value\n";\r
+> +  git ('config', '--unset', 'core.worktree');\r
+> +  git ('config', 'core.bare', 'true');\r
+> +  # create an empty blob (e69de29bb2d1d6434b8b29ae775ad8c2e48c5391)\r
+> +  git ('hash-object', '-w', '--stdin');\r
+> +  git ( { GIT_WORK_TREE => $tempwork }, 'commit', '--allow-empty',\r
+> +        '-m', 'Start a new nmbug repository' );\r
+> +}\r
+> +\r
+>  sub is_committed {\r
+>    my $status = shift;\r
+>    return scalar (@{$status->{added}} ) + scalar (@{$status->{deleted}} ) == 0;\r
+> @@ -610,6 +623,12 @@ Create a local nmbug repository from a remote source.  This wraps\r
+>  C<git clone>, adding some options to avoid creating a working tree\r
+>  while preserving remote-tracking branches and upstreams.\r
+>  \r
+> +=item B<init>\r
+> +\r
+> +Create a local nmbug repository from scratch.  This wraps C<git init>\r
+> +and performs other setup to support subsequent status and commit\r
+> +commands.\r
+> +\r
+>  =item B<checkout>\r
+>  \r
+>  Update the notmuch database from git. This is mainly useful to discard\r
+> -- \r
+> 1.9.1.353.gc66d89d\r