summary | shortlog | log | commit | commitdiff | tree
raw | patch | inline | side by side (parent: ca4c7db)
raw | patch | inline | side by side (parent: ca4c7db)
author | Linus Torvalds <torvalds@ppc970.osdl.org> | |
Mon, 2 May 2005 02:28:18 +0000 (19:28 -0700) | ||
committer | Linus Torvalds <torvalds@ppc970.osdl.org> | |
Mon, 2 May 2005 02:28:18 +0000 (19:28 -0700) |
This means that you can take a tag object, and do
git-cat-file commit tagname
and it will cat the commit that the tag points to. Or you can
cat the tree that a commit (or tag) points to.
It still gives the old behaviour if you just give it the
original type, ie if you want to see the tag object itself,
you'd do
git-cat-file -t tagname
and you'd get the expected tag output.
git-cat-file commit tagname
and it will cat the commit that the tag points to. Or you can
cat the tree that a commit (or tag) points to.
It still gives the old behaviour if you just give it the
original type, ie if you want to see the tag object itself,
you'd do
git-cat-file -t tagname
and you'd get the expected tag output.
cat-file.c | patch | blob | history |
diff --git a/cat-file.c b/cat-file.c
index d253ff93807fa9bbd66e7cd278f213e06644c31e..6bbb0ca0174265626a228b143fe348f4eb186f0c 100644 (file)
--- a/cat-file.c
+++ b/cat-file.c
if (argc != 3 || get_sha1(argv[2], sha1))
usage("cat-file [-t | tagname] <sha1>");
- buf = read_sha1_file(sha1, type, &size);
- if (!buf)
- die("cat-file %s: bad file", argv[2]);
+
if (!strcmp("-t", argv[1])) {
- buf = type;
- size = strlen(type);
- type[size] = '\n';
- size++;
- } else if (strcmp(type, argv[1])) {
- die("cat-file %s: bad tag", argv[2]);
+ buf = read_sha1_file(sha1, type, &size);
+ if (buf) {
+ buf = type;
+ size = strlen(type);
+ type[size] = '\n';
+ }
+ } else {
+ buf = read_object_with_reference(sha1, argv[1], &size, NULL);
}
+ if (!buf)
+ die("cat-file %s: bad file", argv[2]);
+
while (size > 0) {
long ret = write(1, buf, size);
if (ret < 0) {