diff options
author | Linus Torvalds <torvalds@ppc970.osdl.org> | 2005-04-18 12:12:00 -0700 |
---|---|---|
committer | Linus Torvalds <torvalds@ppc970.osdl.org> | 2005-04-18 12:12:00 -0700 |
commit | b51ad4314078298194d23d46e2b4473ffd32a88a (patch) | |
tree | 3dfffcf747e4fbdb04f1b43251be932f69f55476 /blob.c | |
parent | a4b7dbef4ef53f4fffbda0a6f5eada4c377e3fc5 (diff) | |
parent | b5039db6d25ae25f1cb2db541ed13602784fafc3 (diff) | |
download | git-b51ad4314078298194d23d46e2b4473ffd32a88a.tar.gz |
Merge the new object model thing from Daniel Barkalow
This was a real git merge with conflicts. I'll commit the scripts I used
to do the merge next.
Not pretty, but it's half-way functional.
Diffstat (limited to 'blob.c')
-rw-r--r-- | blob.c | 24 |
1 files changed, 24 insertions, 0 deletions
diff --git a/blob.c b/blob.c new file mode 100644 index 0000000000..35031af62b --- /dev/null +++ b/blob.c @@ -0,0 +1,24 @@ +#include "blob.h" +#include "cache.h" +#include <stdlib.h> + +const char *blob_type = "blob"; + +struct blob *lookup_blob(unsigned char *sha1) +{ + struct object *obj = lookup_object(sha1); + if (!obj) { + struct blob *ret = malloc(sizeof(struct blob)); + memset(ret, 0, sizeof(struct blob)); + created_object(sha1, &ret->object); + ret->object.type = blob_type; + ret->object.parsed = 1; + return ret; + } + if (obj->parsed && obj->type != blob_type) { + error("Object %s is a %s, not a blob", + sha1_to_hex(sha1), obj->type); + return NULL; + } + return (struct blob *) obj; +} |