diff options
| author | Junio C Hamano <gitster@pobox.com> | 2017-11-06 14:24:24 +0900 | 
|---|---|---|
| committer | Junio C Hamano <gitster@pobox.com> | 2017-11-06 14:24:24 +0900 | 
| commit | fb4cd88ad47da361e5b1a93dde71c61b9dfa2cd2 (patch) | |
| tree | 4233d3847c9dfec1cebbed8f354741431fdfc57a | |
| parent | a1bf46ed9dfe67ce07f351e0fd9b9cfe68740d6c (diff) | |
| parent | 3a4d2c743750dbc3c8165f362c0a3c0d1c775c8a (diff) | |
| download | git-fb4cd88ad47da361e5b1a93dde71c61b9dfa2cd2.tar.gz | |
Merge branch 'wk/pull-signoff'
"git pull" has been taught to accept "--[no-]signoff" option and
pass it down to "git merge".
* wk/pull-signoff:
  pull: pass --signoff/--no-signoff to "git merge"
| -rw-r--r-- | Documentation/git-merge.txt | 8 | ||||
| -rw-r--r-- | Documentation/merge-options.txt | 10 | ||||
| -rw-r--r-- | builtin/pull.c | 6 | ||||
| -rwxr-xr-x | t/t5521-pull-options.sh | 45 | 
4 files changed, 61 insertions, 8 deletions
| diff --git a/Documentation/git-merge.txt b/Documentation/git-merge.txt index 3c6927b1fb..d5dfd8430f 100644 --- a/Documentation/git-merge.txt +++ b/Documentation/git-merge.txt @@ -64,14 +64,6 @@ OPTIONS  -------  include::merge-options.txt[] ---signoff:: -	Add Signed-off-by line by the committer at the end of the commit -	log message.  The meaning of a signoff depends on the project, -	but it typically certifies that committer has -	the rights to submit this work under the same license and -	agrees to a Developer Certificate of Origin -	(see http://developercertificate.org/ for more information). -  -m <msg>::  	Set the commit message to be used for the merge commit (in  	case one is created). diff --git a/Documentation/merge-options.txt b/Documentation/merge-options.txt index 2552ab8e8d..3888c3ff85 100644 --- a/Documentation/merge-options.txt +++ b/Documentation/merge-options.txt @@ -57,6 +57,16 @@ set to `no` at the beginning of them.  With --no-log do not list one-line descriptions from the  actual commits being merged. +--signoff:: +--no-signoff:: +	Add Signed-off-by line by the committer at the end of the commit +	log message.  The meaning of a signoff depends on the project, +	but it typically certifies that committer has +	the rights to submit this work under the same license and +	agrees to a Developer Certificate of Origin +	(see http://developercertificate.org/ for more information). ++ +With --no-signoff do not add a Signed-off-by line.  --stat::  -n:: diff --git a/builtin/pull.c b/builtin/pull.c index 6f772e8a22..0413c78a3a 100644 --- a/builtin/pull.c +++ b/builtin/pull.c @@ -86,6 +86,7 @@ static int recurse_submodules = RECURSE_SUBMODULES_DEFAULT;  static enum rebase_type opt_rebase = -1;  static char *opt_diffstat;  static char *opt_log; +static char *opt_signoff;  static char *opt_squash;  static char *opt_commit;  static char *opt_edit; @@ -142,6 +143,9 @@ static struct option pull_options[] = {  	OPT_PASSTHRU(0, "log", &opt_log, N_("n"),  		N_("add (at most <n>) entries from shortlog to merge commit message"),  		PARSE_OPT_OPTARG), +	OPT_PASSTHRU(0, "signoff", &opt_signoff, NULL, +		N_("add Signed-off-by:"), +		PARSE_OPT_OPTARG),  	OPT_PASSTHRU(0, "squash", &opt_squash, NULL,  		N_("create a single commit instead of doing a merge"),  		PARSE_OPT_NOARG), @@ -594,6 +598,8 @@ static int run_merge(void)  		argv_array_push(&args, opt_diffstat);  	if (opt_log)  		argv_array_push(&args, opt_log); +	if (opt_signoff) +		argv_array_push(&args, opt_signoff);  	if (opt_squash)  		argv_array_push(&args, opt_squash);  	if (opt_commit) diff --git a/t/t5521-pull-options.sh b/t/t5521-pull-options.sh index ded8f98dbe..c19d8dbc9d 100755 --- a/t/t5521-pull-options.sh +++ b/t/t5521-pull-options.sh @@ -165,4 +165,49 @@ test_expect_success 'git pull --allow-unrelated-histories' '  	)  ' +test_expect_success 'git pull does not add a sign-off line' ' +	test_when_finished "rm -fr src dst actual" && +	git init src && +	test_commit -C src one && +	git clone src dst && +	test_commit -C src two && +	git -C dst pull --no-ff && +	git -C dst show -s --pretty="format:%(trailers)" HEAD >actual && +	test_must_be_empty actual +' + +test_expect_success 'git pull --no-signoff does not add sign-off line' ' +	test_when_finished "rm -fr src dst actual" && +	git init src && +	test_commit -C src one && +	git clone src dst && +	test_commit -C src two && +	git -C dst pull --no-signoff --no-ff && +	git -C dst show -s --pretty="format:%(trailers)" HEAD >actual && +	test_must_be_empty actual +' + +test_expect_success 'git pull --signoff add a sign-off line' ' +	test_when_finished "rm -fr src dst expected actual" && +	echo "Signed-off-by: $GIT_COMMITTER_NAME <$GIT_COMMITTER_EMAIL>" >expected && +	git init src && +	test_commit -C src one && +	git clone src dst && +	test_commit -C src two && +	git -C dst pull --signoff --no-ff && +	git -C dst show -s --pretty="format:%(trailers)" HEAD >actual && +	test_cmp expected actual +' + +test_expect_success 'git pull --no-signoff flag cancels --signoff flag' ' +	test_when_finished "rm -fr src dst actual" && +	git init src && +	test_commit -C src one && +	git clone src dst && +	test_commit -C src two && +	git -C dst pull --signoff --no-signoff --no-ff && +	git -C dst show -s --pretty="format:%(trailers)" HEAD >actual && +	test_must_be_empty actual +' +  test_done | 
