X-Git-Url: https://git.octo.it/?a=blobdiff_plain;f=cat-file.c;h=be41f516664bc96ebec77c9ab88c3ab8df02ddfa;hb=dfe070511c652f2b8e1bf6540f238c9ca9ba41d3;hp=3829fb6097ad9840cca7654f0b8a718100d590ac;hpb=19b2860cba5742ab31fd682b80fefefac19be141;p=git.git diff --git a/cat-file.c b/cat-file.c index 3829fb60..be41f516 100644 --- a/cat-file.c +++ b/cat-file.c @@ -12,23 +12,24 @@ int main(int argc, char **argv) void *buf; unsigned long size; - if (argc != 3 || get_sha1_hex(argv[2], sha1)) - usage("cat-file: cat-file [-t | tagname] "); - buf = read_sha1_file(sha1, type, &size); - if (!buf) { - fprintf(stderr, "cat-file %s: bad file\n", argv[2]); - exit(1); - } + if (argc != 3 || get_sha1(argv[2], sha1)) + usage("git-cat-file [-t | tagname] "); + if (!strcmp("-t", argv[1])) { - buf = type; - size = strlen(type); - type[size] = '\n'; - size++; - } else if (strcmp(type, argv[1])) { - fprintf(stderr, "cat-file %s: bad tag\n", argv[2]); - exit(1); /* bad tag */ + buf = read_sha1_file(sha1, type, &size); + if (buf) { + buf = type; + size = strlen(type); + type[size] = '\n'; + size++; + } + } else { + buf = read_object_with_reference(sha1, argv[1], &size, NULL); } + if (!buf) + die("git-cat-file %s: bad file", argv[2]); + while (size > 0) { long ret = write(1, buf, size); if (ret < 0) { @@ -37,12 +38,9 @@ int main(int argc, char **argv) /* Ignore epipe */ if (errno == EPIPE) break; - fprintf(stderr, "cat-file: %s\n", strerror(errno)); - exit(1); - } - if (!ret) { - fprintf(stderr, "cat-file: disk full?"); - exit(1); + die("git-cat-file: %s", strerror(errno)); + } else if (!ret) { + die("git-cat-file: disk full?"); } size -= ret; buf += ret;