* [PATCH] Add -v and --abbrev options to git-branch
@ 2006-11-24 13:45 Lars Hjemli
2006-11-24 14:04 ` Jakub Narebski
0 siblings, 1 reply; 3+ messages in thread
From: Lars Hjemli @ 2006-11-24 13:45 UTC (permalink / raw)
To: git
The new -v option makes git-branch show the abbreviated sha1 + subjectline
for each branch.
Additionally, minimum abbreviation length can be specified with
--abbrev=<length>
Signed-off-by: Lars Hjemli <hjemli@gmail.com>
---
Documentation/git-branch.txt | 9 +++++++-
builtin-branch.c | 46 ++++++++++++++++++++++++++++++++++++-----
2 files changed, 48 insertions(+), 7 deletions(-)
diff --git a/Documentation/git-branch.txt b/Documentation/git-branch.txt
index 5376760..4f5b5d5 100644
--- a/Documentation/git-branch.txt
+++ b/Documentation/git-branch.txt
@@ -8,7 +8,7 @@ git-branch - List, create, or delete bra
SYNOPSIS
--------
[verse]
-'git-branch' [-r] [-a]
+'git-branch' [-r] [-a] [-v] [--abbrev=<length>]
'git-branch' [-l] [-f] <branchname> [<start-point>]
'git-branch' (-d | -D) <branchname>...
@@ -52,6 +52,13 @@ OPTIONS
-a::
List both remote-tracking branches and local branches.
+-v::
+ Show sha1 and subject message for each head.
+
+--abbrev=<length>::
+ Alter minimum display length for sha1 in output listing,
+ default value is 7.
+
<branchname>::
The name of the branch to create or delete.
The new branch name must pass all checks defined by
diff --git a/builtin-branch.c b/builtin-branch.c
index 22e3285..f14d814 100644
--- a/builtin-branch.c
+++ b/builtin-branch.c
@@ -11,7 +11,7 @@
#include "builtin.h"
static const char builtin_branch_usage[] =
-"git-branch (-d | -D) <branchname> | [-l] [-f] <branchname> [<start-point>] | [-r] | [-a]";
+"git-branch (-d | -D) <branchname> | [-l] [-f] <branchname> [<start-point>] | [-r | -a] [-v] [--abbrev=<length>] ";
static const char *head;
@@ -87,10 +87,11 @@ static void delete_branches(int argc, co
struct ref_item {
char *name;
unsigned int kind;
+ unsigned char sha1[20];
};
struct ref_list {
- int index, alloc;
+ int index, alloc, maxwidth;
struct ref_item *list;
int kinds;
};
@@ -100,6 +101,7 @@ static int append_ref(const char *refnam
struct ref_list *ref_list = (struct ref_list*)(cb_data);
struct ref_item *newitem;
int kind = REF_UNKNOWN_TYPE;
+ int len;
/* Detect kind */
if (!strncmp(refname, "refs/heads/", 11)) {
@@ -128,6 +130,10 @@ static int append_ref(const char *refnam
newitem = &(ref_list->list[ref_list->index++]);
newitem->name = xstrdup(refname);
newitem->kind = kind;
+ memcpy(newitem->sha1, sha1, 20);
+ len = strlen(newitem->name);
+ if (len > ref_list->maxwidth)
+ ref_list->maxwidth = len;
return 0;
}
@@ -151,7 +157,24 @@ static int ref_cmp(const void *r1, const
return strcmp(c1->name, c2->name);
}
-static void print_ref_list(int kinds)
+static void print_ref_info(const unsigned char *sha1, int abbrev)
+{
+ struct commit *commit;
+ char subject[256];
+
+
+ commit = lookup_commit(sha1);
+ if (commit && !parse_commit(commit))
+ pretty_print_commit(CMIT_FMT_ONELINE, commit, ~0,
+ subject, sizeof(subject), 0,
+ NULL, NULL, 0);
+ else
+ sprintf(subject, " **** invalid ref ****");
+
+ printf(" %s %s", find_unique_abbrev(sha1, abbrev), subject);
+}
+
+static void print_ref_list(int kinds, int verbose, int abbrev)
{
int i;
char c;
@@ -169,9 +192,11 @@ static void print_ref_list(int kinds)
!strcmp(ref_list.list[i].name, head))
c = '*';
- printf("%c %s\n", c, ref_list.list[i].name);
+ printf("%c %-*s", c, ref_list.maxwidth, ref_list.list[i].name);
+ if (verbose)
+ print_ref_info(ref_list.list[i].sha1, abbrev);
+ printf("\n");
}
-
free_ref_list(&ref_list);
}
@@ -215,6 +240,7 @@ static void create_branch(const char *na
int cmd_branch(int argc, const char **argv, const char *prefix)
{
int delete = 0, force_delete = 0, force_create = 0;
+ int verbose = 0, abbrev = DEFAULT_ABBREV;
int reflog = 0;
int kinds = REF_LOCAL_BRANCH;
int i;
@@ -255,6 +281,14 @@ int cmd_branch(int argc, const char **ar
reflog = 1;
continue;
}
+ if (!strncmp(arg, "--abbrev=", 9)) {
+ abbrev = atoi(arg+9);
+ continue;
+ }
+ if (!strcmp(arg, "-v")) {
+ verbose = 1;
+ continue;
+ }
usage(builtin_branch_usage);
}
@@ -268,7 +302,7 @@ int cmd_branch(int argc, const char **ar
if (delete)
delete_branches(argc - i, argv + i, force_delete);
else if (i == argc)
- print_ref_list(kinds);
+ print_ref_list(kinds, verbose, abbrev);
else if (i == argc - 1)
create_branch(argv[i], head, force_create, reflog);
else if (i == argc - 2)
--
1.4.4
^ permalink raw reply related [flat|nested] 3+ messages in thread
* Re: [PATCH] Add -v and --abbrev options to git-branch
2006-11-24 13:45 [PATCH] Add -v and --abbrev options to git-branch Lars Hjemli
@ 2006-11-24 14:04 ` Jakub Narebski
2006-11-24 15:22 ` Lars Hjemli
0 siblings, 1 reply; 3+ messages in thread
From: Jakub Narebski @ 2006-11-24 14:04 UTC (permalink / raw)
To: git
Lars Hjemli wrote:
> The new -v option makes git-branch show the abbreviated sha1 + subjectline
> for each branch.
Isn't what git-show-ref is about? Or git-for-each-ref?
--
Jakub Narebski
Warsaw, Poland
ShadeHawk on #git
^ permalink raw reply [flat|nested] 3+ messages in thread
* Re: [PATCH] Add -v and --abbrev options to git-branch
2006-11-24 14:04 ` Jakub Narebski
@ 2006-11-24 15:22 ` Lars Hjemli
0 siblings, 0 replies; 3+ messages in thread
From: Lars Hjemli @ 2006-11-24 15:22 UTC (permalink / raw)
To: git
On 11/24/06, Jakub Narebski <jnareb@gmail.com> wrote:
> Isn't what git-show-ref is about? Or git-for-each-ref?
Yes, there seem to be some overlap in functionality here :-)
The thing with git-branch is that it shows me which branch I'm
currently on, someting neither git-show-ref nor git-for-each-ref does.
And the "starred" branch, combined with hash and commit subject is
very useful for me (It reminds me where I am, and where I have been,
and what i did there....)
Finally, git-for-each-ref is more like plumbing, I wanted someting a
little more userfriendly
--
^ permalink raw reply [flat|nested] 3+ messages in thread
end of thread, other threads:[~2006-11-24 15:22 UTC | newest]
Thread overview: 3+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2006-11-24 13:45 [PATCH] Add -v and --abbrev options to git-branch Lars Hjemli
2006-11-24 14:04 ` Jakub Narebski
2006-11-24 15:22 ` Lars Hjemli
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).