check-ref-format --branch: give Porcelain a way to grok branch shorthand
The command may not be the best place to add this new feature, but $ git check-ref-format --branch "@{-1}" allows Porcelains to figure out what branch you were on before the last branch switching. Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
parent
a552de75eb
commit
a31dca0393
@ -7,7 +7,9 @@ git-check-ref-format - Make sure ref name is well formed
|
|||||||
|
|
||||||
SYNOPSIS
|
SYNOPSIS
|
||||||
--------
|
--------
|
||||||
|
[verse]
|
||||||
'git check-ref-format' <refname>
|
'git check-ref-format' <refname>
|
||||||
|
'git check-ref-format' [--branch] <branchname-shorthand>
|
||||||
|
|
||||||
DESCRIPTION
|
DESCRIPTION
|
||||||
-----------
|
-----------
|
||||||
@ -49,6 +51,16 @@ refname expressions (see linkgit:git-rev-parse[1]). Namely:
|
|||||||
It may also be used to select a specific object such as with
|
It may also be used to select a specific object such as with
|
||||||
'git-cat-file': "git cat-file blob v1.3.3:refs.c".
|
'git-cat-file': "git cat-file blob v1.3.3:refs.c".
|
||||||
|
|
||||||
|
With the `--branch` option, it expands a branch name shorthand and
|
||||||
|
prints the name of the branch the shorthand refers to.
|
||||||
|
|
||||||
|
EXAMPLE
|
||||||
|
-------
|
||||||
|
|
||||||
|
git check-ref-format --branch @{-1}::
|
||||||
|
|
||||||
|
Print the name of the previous branch.
|
||||||
|
|
||||||
|
|
||||||
GIT
|
GIT
|
||||||
---
|
---
|
||||||
|
@ -5,9 +5,19 @@
|
|||||||
#include "cache.h"
|
#include "cache.h"
|
||||||
#include "refs.h"
|
#include "refs.h"
|
||||||
#include "builtin.h"
|
#include "builtin.h"
|
||||||
|
#include "strbuf.h"
|
||||||
|
|
||||||
int cmd_check_ref_format(int argc, const char **argv, const char *prefix)
|
int cmd_check_ref_format(int argc, const char **argv, const char *prefix)
|
||||||
{
|
{
|
||||||
|
if (argc == 3 && !strcmp(argv[1], "--branch")) {
|
||||||
|
struct strbuf sb = STRBUF_INIT;
|
||||||
|
strbuf_branchname(&sb, argv[2]);
|
||||||
|
strbuf_splice(&sb, 0, 0, "refs/heads/", 11);
|
||||||
|
if (check_ref_format(sb.buf))
|
||||||
|
die("'%s' is not a valid branch name", argv[2]);
|
||||||
|
printf("%s\n", sb.buf + 11);
|
||||||
|
exit(0);
|
||||||
|
}
|
||||||
if (argc != 2)
|
if (argc != 2)
|
||||||
usage("git check-ref-format refname");
|
usage("git check-ref-format refname");
|
||||||
return !!check_ref_format(argv[1]);
|
return !!check_ref_format(argv[1]);
|
||||||
|
Loading…
Reference in New Issue
Block a user