Add an option to git-ls-tree to display also the size of blob

Add -l/--long option to git-ls-tree command, which displays
object size of a blob entry.  Object size is placed after
object id (left-justified with minimum width of 7 characters).
For non-blob entries `-' is used.

Rationale: for non-blob entries size of an object has no much
meaning, and is not very interesting.  Moreover, in planned
pack v4 tree objects would be constructed on demand, so tree
size would need to be calculated.

Signed-off-by: Jakub Narebski <jnareb@gmail.com>
Signed-off-by: Junio C Hamano <junkio@cox.net>
This commit is contained in:
Jakub Narebski 2007-05-19 22:08:11 +02:00 committed by Junio C Hamano
parent 93d496a560
commit a5bbda8b7b
2 changed files with 41 additions and 6 deletions

View File

@ -9,7 +9,7 @@ git-ls-tree - List the contents of a tree object
SYNOPSIS SYNOPSIS
-------- --------
[verse] [verse]
'git-ls-tree' [-d] [-r] [-t] [-z] 'git-ls-tree' [-d] [-r] [-t] [-l] [-z]
[--name-only] [--name-status] [--full-name] [--abbrev=[<n>]] [--name-only] [--name-status] [--full-name] [--abbrev=[<n>]]
<tree-ish> [paths...] <tree-ish> [paths...]
@ -36,6 +36,10 @@ OPTIONS
Show tree entries even when going to recurse them. Has no effect Show tree entries even when going to recurse them. Has no effect
if '-r' was not passed. '-d' implies '-t'. if '-r' was not passed. '-d' implies '-t'.
-l::
--long::
Show object size of blob (file) entries.
-z:: -z::
\0 line termination on output. \0 line termination on output.
@ -65,6 +69,14 @@ Output Format
When the `-z` option is not used, TAB, LF, and backslash characters When the `-z` option is not used, TAB, LF, and backslash characters
in pathnames are represented as `\t`, `\n`, and `\\`, respectively. in pathnames are represented as `\t`, `\n`, and `\\`, respectively.
When the `-l` option is used, format changes to
<mode> SP <type> SP <object> SP <object size> TAB <file>
Object size identified by <object> is given in bytes, and right-justified
with minimum width of 7 characters. Object size is given only for blobs
(file) entries; for other entries `-` character is used in place of size.
Author Author
------ ------

View File

@ -15,6 +15,7 @@ static int line_termination = '\n';
#define LS_TREE_ONLY 2 #define LS_TREE_ONLY 2
#define LS_SHOW_TREES 4 #define LS_SHOW_TREES 4
#define LS_NAME_ONLY 8 #define LS_NAME_ONLY 8
#define LS_SHOW_SIZE 16
static int abbrev; static int abbrev;
static int ls_options; static int ls_options;
static const char **pathspec; static const char **pathspec;
@ -22,7 +23,7 @@ static int chomp_prefix;
static const char *ls_tree_prefix; static const char *ls_tree_prefix;
static const char ls_tree_usage[] = static const char ls_tree_usage[] =
"git-ls-tree [-d] [-r] [-t] [-z] [--name-only] [--name-status] [--full-name] [--abbrev[=<n>]] <tree-ish> [path...]"; "git-ls-tree [-d] [-r] [-t] [-l] [-z] [--name-only] [--name-status] [--full-name] [--abbrev[=<n>]] <tree-ish> [path...]";
static int show_recursive(const char *base, int baselen, const char *pathname) static int show_recursive(const char *base, int baselen, const char *pathname)
{ {
@ -59,6 +60,7 @@ static int show_tree(const unsigned char *sha1, const char *base, int baselen,
{ {
int retval = 0; int retval = 0;
const char *type = blob_type; const char *type = blob_type;
unsigned long size;
if (S_ISDIRLNK(mode)) { if (S_ISDIRLNK(mode)) {
/* /*
@ -92,10 +94,24 @@ static int show_tree(const unsigned char *sha1, const char *base, int baselen,
(baselen < chomp_prefix || memcmp(ls_tree_prefix, base, chomp_prefix))) (baselen < chomp_prefix || memcmp(ls_tree_prefix, base, chomp_prefix)))
return 0; return 0;
if (!(ls_options & LS_NAME_ONLY)) if (!(ls_options & LS_NAME_ONLY)) {
printf("%06o %s %s\t", mode, type, if (ls_options & LS_SHOW_SIZE) {
abbrev ? find_unique_abbrev(sha1,abbrev) if (!strcmp(type, blob_type)) {
: sha1_to_hex(sha1)); sha1_object_info(sha1, &size);
printf("%06o %s %s %7lu\t", mode, type,
abbrev ? find_unique_abbrev(sha1, abbrev)
: sha1_to_hex(sha1),
size);
} else
printf("%06o %s %s %7c\t", mode, type,
abbrev ? find_unique_abbrev(sha1, abbrev)
: sha1_to_hex(sha1),
'-');
} else
printf("%06o %s %s\t", mode, type,
abbrev ? find_unique_abbrev(sha1, abbrev)
: sha1_to_hex(sha1));
}
write_name_quoted(base + chomp_prefix, baselen - chomp_prefix, write_name_quoted(base + chomp_prefix, baselen - chomp_prefix,
pathname, pathname,
line_termination, stdout); line_termination, stdout);
@ -126,12 +142,19 @@ int cmd_ls_tree(int argc, const char **argv, const char *prefix)
case 't': case 't':
ls_options |= LS_SHOW_TREES; ls_options |= LS_SHOW_TREES;
break; break;
case 'l':
ls_options |= LS_SHOW_SIZE;
break;
case '-': case '-':
if (!strcmp(argv[1]+2, "name-only") || if (!strcmp(argv[1]+2, "name-only") ||
!strcmp(argv[1]+2, "name-status")) { !strcmp(argv[1]+2, "name-status")) {
ls_options |= LS_NAME_ONLY; ls_options |= LS_NAME_ONLY;
break; break;
} }
if (!strcmp(argv[1]+2, "long")) {
ls_options |= LS_SHOW_SIZE;
break;
}
if (!strcmp(argv[1]+2, "full-name")) { if (!strcmp(argv[1]+2, "full-name")) {
chomp_prefix = 0; chomp_prefix = 0;
break; break;