branch: improve error log on branch not found by checking remotes refs

New git users may want to locally delete remote-tracking branches but
don't really understand how they are distinguished from branches by git.
Then one may naively try:
`git branch -d foo/bar` and get a correct error `branch foo/bar not
found` but hard to understand for a newbie, this patch aims to guide one
in such case.

when failing to delete a branch with `git branch -d <branch>` because
of branch not found, try to find a **remote refs** matching `<branch>`
and if so, add an hint:
`Did you forget --remote?` to the error message

Signed-off-by: Clement Mabileau <mabileau.clement@gmail.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
Clement Mabileau 2023-04-05 11:43:20 +00:00 committed by Junio C Hamano
parent ae73b2c8f1
commit 4c643fb321

View File

@ -216,10 +216,11 @@ static int delete_branches(int argc, const char **argv, int force, int kinds,
struct string_list refs_to_delete = STRING_LIST_INIT_DUP; struct string_list refs_to_delete = STRING_LIST_INIT_DUP;
struct string_list_item *item; struct string_list_item *item;
int branch_name_pos; int branch_name_pos;
const char *fmt_remotes = "refs/remotes/%s";
switch (kinds) { switch (kinds) {
case FILTER_REFS_REMOTES: case FILTER_REFS_REMOTES:
fmt = "refs/remotes/%s"; fmt = fmt_remotes;
/* For subsequent UI messages */ /* For subsequent UI messages */
remote_branch = 1; remote_branch = 1;
allowed_interpret = INTERPRET_BRANCH_REMOTE; allowed_interpret = INTERPRET_BRANCH_REMOTE;
@ -263,9 +264,25 @@ static int delete_branches(int argc, const char **argv, int force, int kinds,
| RESOLVE_REF_ALLOW_BAD_NAME, | RESOLVE_REF_ALLOW_BAD_NAME,
&oid, &flags); &oid, &flags);
if (!target) { if (!target) {
error(remote_branch if (remote_branch) {
? _("remote-tracking branch '%s' not found.") error(_("remote-tracking branch '%s' not found."), bname.buf);
: _("branch '%s' not found."), bname.buf); } else {
char *virtual_name = mkpathdup(fmt_remotes, bname.buf);
char *virtual_target = resolve_refdup(virtual_name,
RESOLVE_REF_READING
| RESOLVE_REF_NO_RECURSE
| RESOLVE_REF_ALLOW_BAD_NAME,
&oid, &flags);
FREE_AND_NULL(virtual_name);
if (virtual_target)
error(_("branch '%s' not found.\n"
"Did you forget --remote?"),
bname.buf);
else
error(_("branch '%s' not found."), bname.buf);
FREE_AND_NULL(virtual_target);
}
ret = 1; ret = 1;
continue; continue;
} }