diff options
author | Stanislav Kolotinskiy <stanislav@assembla.com> | 2016-03-31 16:55:09 +0300 |
---|---|---|
committer | Junio C Hamano <gitster@pobox.com> | 2016-03-31 14:58:26 -0700 |
commit | c6777563cd2b3e1d1989732c3daf05a72fddb068 (patch) | |
tree | 28a0b6564a1bdc68ffa112714ea5bf4358c87e47 /builtin/send-pack.c | |
parent | push: add a config option push.gpgSign for default signed pushes (diff) | |
download | tgif-c6777563cd2b3e1d1989732c3daf05a72fddb068.tar.xz |
git-send-pack: fix --all option when used with directory
When using git send-pack with --all option
and a target repository specification ([<host>:]<directory>),
usage message is being displayed instead of performing
the actual transmission.
The reason for this issue is that destination and refspecs are being set
in the same conditional and are populated from argv. When a target
repository is passed, refspecs is being populated as well with its value.
This makes the check for refspecs not being NULL to always return true,
which, in conjunction with the check for --all or --mirror options,
is always true as well and returns usage message instead of proceeding.
This ensures that send-pack will stop execution only when --all
or --mirror switch is used in conjunction with any refspecs passed.
Signed-off-by: Stanislav Kolotinskiy <stanislav@assembla.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to 'builtin/send-pack.c')
-rw-r--r-- | builtin/send-pack.c | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/builtin/send-pack.c b/builtin/send-pack.c index f6e5d643c1..19f0577fa0 100644 --- a/builtin/send-pack.c +++ b/builtin/send-pack.c @@ -225,7 +225,7 @@ int cmd_send_pack(int argc, const char **argv, const char *prefix) * --all and --mirror are incompatible; neither makes sense * with any refspecs. */ - if ((refspecs && (send_all || args.send_mirror)) || + if ((nr_refspecs > 0 && (send_all || args.send_mirror)) || (send_all && args.send_mirror)) usage_with_options(send_pack_usage, options); |