X-Git-Url: https://git.octo.it/?a=blobdiff_plain;f=cat-file.c;h=d775a1545beb84caf05cae8980fb2d839240fdea;hb=4ddba79db76bd6425f00e99ceb1d82d179319aec;hp=6ff9d5576a4317020b5a42cb90846668a2a6ca40;hpb=fa9e9c7bc4d6437537a78517f7f6909340e25ad9;p=git.git diff --git a/cat-file.c b/cat-file.c index 6ff9d557..d775a154 100644 --- a/cat-file.c +++ b/cat-file.c @@ -12,23 +12,30 @@ int main(int argc, char **argv) void *buf; unsigned long size; + setup_git_directory(); if (argc != 3 || get_sha1(argv[2], sha1)) - usage("cat-file [-t | tagname] "); + usage("git-cat-file [-t | -s | ] "); - if (!strcmp("-t", argv[1])) { - buf = read_sha1_file(sha1, type, &size); - if (buf) { - buf = type; - size = strlen(type); - type[size] = '\n'; - size++; + if (!strcmp("-t", argv[1]) || !strcmp("-s", argv[1])) { + if (!sha1_object_info(sha1, type, + argv[1][1] == 's' ? &size : NULL)) { + switch (argv[1][1]) { + case 't': + printf("%s\n", type); + break; + case 's': + printf("%lu\n", size); + break; + } + return 0; } + buf = NULL; } else { buf = read_object_with_reference(sha1, argv[1], &size, NULL); } if (!buf) - die("cat-file %s: bad file", argv[2]); + die("git-cat-file %s: bad file", argv[2]); while (size > 0) { long ret = write(1, buf, size); @@ -38,9 +45,9 @@ int main(int argc, char **argv) /* Ignore epipe */ if (errno == EPIPE) break; - die("cat-file: %s", strerror(errno)); + die("git-cat-file: %s", strerror(errno)); } else if (!ret) { - die("cat-file: disk full?"); + die("git-cat-file: disk full?"); } size -= ret; buf += ret;