All of lore.kernel.org
 help / color / mirror / Atom feed
From: "H. Peter Anvin" <hpa@zytor.com>
To: Git Mailing List <git@vger.kernel.org>
Subject: [PATCH] git-am --one
Date: Tue, 13 Dec 2005 17:10:29 -0800	[thread overview]
Message-ID: <439F7105.9050302@zytor.com> (raw)

[-- Attachment #1: Type: text/plain, Size: 344 bytes --]

This patch adds the --one (-o) option to git-am, to apply a single 
message in RFC 2822 format, as opposed to an mbox.  With some MUAs it's 
a lot easier to save individual messages than with mboxes, and either 
way the user may want to control the ordering if there are known 
interdependencies.

Signed-off-by: H. Peter Anvin <hpa@zytor.com>

[-- Attachment #2: git-am-one --]
[-- Type: text/plain, Size: 2100 bytes --]

diff --git a/Documentation/git-am.txt b/Documentation/git-am.txt
index a415fe2..bec5c84 100644
--- a/Documentation/git-am.txt
+++ b/Documentation/git-am.txt
@@ -8,7 +8,7 @@ git-am - Apply a series of patches in a 
 
 SYNOPSIS
 --------
-'git-am' [--signoff] [--dotest=<dir>] [--utf8] [--binary] [--3way] <mbox>...
+'git-am' [--one] [--signoff] [--dotest=<dir>] [--utf8] [--binary] [--3way] <mbox>...
 'git-am' [--skip | --resolved]
 
 DESCRIPTION
@@ -19,6 +19,10 @@ current branch.
 
 OPTIONS
 -------
+--one::
+	Indicates that <mbox> contains a single message in RFC 2822
+	format, without mbox-style separators.
+
 --signoff::
 	Add `Signed-off-by:` line to the commit message, using
 	the committer identity of yourself.
diff --git a/git-am.sh b/git-am.sh
index 6ed527c..9628651 100755
--- a/git-am.sh
+++ b/git-am.sh
@@ -4,7 +4,7 @@
 . git-sh-setup
 
 usage () {
-    echo >&2 "usage: $0 [--signoff] [--dotest=<dir>] [--utf8] [--binary] [--3way] <mbox>"
+    echo >&2 "usage: $0 [--one] [--signoff] [--dotest=<dir>] [--utf8] [--binary] [--3way] <mbox>"
     echo >&2 "	or, when resuming"
     echo >&2 "	$0 [--skip | --resolved]"
     exit 1;
@@ -98,11 +98,13 @@ fall_back_3way () {
 }
 
 prec=4
-dotest=.dotest sign= utf8= keep= skip= interactive= resolved= binary=
+dotest=.dotest sign= utf8= keep= skip= interactive= resolved= binary= one=
 
 while case "$#" in 0) break;; esac
 do
 	case "$1" in
+	-o|--o|--on|--one)
+	one=t; shift;;
 	-d=*|--d=*|--do=*|--dot=*|--dote=*|--dotes=*|--dotest=*)
 	dotest=`expr "$1" : '-[^=]*=\(.*\)'`; shift ;;
 	-d|--d|--do|--dot|--dote|--dotes|--dotest)
@@ -165,8 +167,16 @@ else
 	mkdir -p "$dotest" || exit
 
 	# cat does the right thing for us, including '-' to mean
-	# standard input.
-	cat "$@" |
+	# standard input.  To prepend the header, we thus want a
+	# second cat, sigh...
+	if test "$one" = t
+	then
+		LANG=C date +'From - %a %b %d %T %Y' > "$dotest"/fakefrom
+		fakefrom="$dotest"/fakefrom
+	else
+		fakefrom=/dev/null
+	fi
+	cat "$@" | cat "$fakefrom" - |
 	git-mailsplit -d$prec "$dotest/" >"$dotest/last" || {
 		rm -fr "$dotest"
 		exit 1

             reply	other threads:[~2005-12-14  1:10 UTC|newest]

Thread overview: 6+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2005-12-14  1:10 H. Peter Anvin [this message]
2005-12-14  1:30 ` [PATCH] git-am --one Junio C Hamano
2005-12-14  1:47   ` H. Peter Anvin
2005-12-14  1:54     ` Junio C Hamano
2005-12-14  1:58       ` H. Peter Anvin
2005-12-14  2:06 ` Junio C Hamano

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=439F7105.9050302@zytor.com \
    --to=hpa@zytor.com \
    --cc=git@vger.kernel.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.