Re: [PATCH] transport submodules: correct error message

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Stefan Beller <sbeller@xxxxxxxxxx> writes:

> Trying to push with --recurse-submodules=on-demand would run into
> the same problem. To fix this issue
>     1) specifically mention that we looked for branches on the remote.

That makes an incorrect statement ("not found on any remote"---we
did not inspect all of the said remote, only heads and tags) into an
irrelevant statement ("not found on any remote branch"---the end
user would say "so what?  I know it exists there, it's just that not
all remote refs have corresponding tracking ref locally on our side").

Perhaps it may be an improvement.

>     2) advertise pushing without recursing into submodules. ("Use this
>        command to make the error message go away")

Not mentioning "on-demand" may be an improvement for those who do
use set-up like Dave has, where remote tracking information is
incomplete if you only look at heads and refs, in the sense that we
no longer suggest ineffective workaround.  

But would it be an improvement to suggest --no-recurse-submodules?

This issue seems like a property of the particular set-up, as
opposed to being a one-off issue.  The next, subsequent and probably
all future pushes from that repository will have the same issue
because the root cause is not due to the relative position of
commits we have locally vs the tips of remote, but due to the way
remote tracking is set-up, no?

If that is the case, perhaps configuring push.recurseSubmodules to
turn this off (especially because you plan to turn the defaul to
"check") and not giving the command line option would give a more
pleasant end-user experience, I suspect.


>
> While at it, remove some empty lines, as they blow up the error message.
>
> Reported-by: Dave Borowitz <dborowitz@xxxxxxxxxx>
> Signed-off-by: Stefan Beller <sbeller@xxxxxxxxxx>
> ---
>  transport.c | 12 ++++++------
>  1 file changed, 6 insertions(+), 6 deletions(-)
>
> diff --git a/transport.c b/transport.c
> index 3e8799a611..2445bf0dca 100644
> --- a/transport.c
> +++ b/transport.c
> @@ -883,14 +883,14 @@ static void die_with_unpushed_submodules(struct string_list *needs_pushing)
>  	int i;
>  
>  	fprintf(stderr, _("The following submodule paths contain changes that can\n"
> -			"not be found on any remote:\n"));
> +			"not be found on any remote branch:\n"));
>  	for (i = 0; i < needs_pushing->nr; i++)
>  		fprintf(stderr, "  %s\n", needs_pushing->items[i].string);
> -	fprintf(stderr, _("\nPlease try\n\n"
> -			  "	git push --recurse-submodules=on-demand\n\n"
> -			  "or cd to the path and use\n\n"
> -			  "	git push\n\n"
> -			  "to push them to a remote.\n\n"));
> +	fprintf(stderr, _("\nSuppress submodule checks via\n"
> +			  "	git push --no-recurse-submodules\n"
> +			  "or cd to the path and use\n"
> +			  "	git push\n"
> +			  "to push them to a remote.\n"));
>  
>  	string_list_clear(needs_pushing, 0);



[Index of Archives]     [Linux Kernel Development]     [Gcc Help]     [IETF Annouce]     [DCCP]     [Netdev]     [Networking]     [Security]     [V4L]     [Bugtraq]     [Yosemite]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux RAID]     [Linux SCSI]     [Fedora Users]