diff options
| author | Linus Torvalds <torvalds@ppc970.osdl.org> | 2005-05-18 16:14:22 -0700 | 
|---|---|---|
| committer | Linus Torvalds <torvalds@ppc970.osdl.org> | 2005-05-18 16:14:22 -0700 | 
| commit | 961784ee422c22075e131292b2235782e378c612 (patch) | |
| tree | d79eca9b37e7ec984fb64b3f33bdc8d43f25c4be /commit.c | |
| parent | fbab835c03f1c73e4de920d00cd26519506d33fe (diff) | |
| download | git-961784ee422c22075e131292b2235782e378c612.tar.gz | |
commit: add "lookup_commit_reference()" helper function
It's pretty much the same as "lookup_commit()", but it will take
tags too, and look up the commit (if any) associated with them.
Diffstat (limited to 'commit.c')
| -rw-r--r-- | commit.c | 29 | 
1 files changed, 23 insertions, 6 deletions
| @@ -1,3 +1,4 @@ +#include "tag.h"  #include "commit.h"  #include "cache.h"  #include <string.h> @@ -5,6 +6,27 @@  const char *commit_type = "commit"; +static struct commit *check_commit(struct object *obj, unsigned char *sha1) +{ +	if (obj->type != commit_type) { +		error("Object %s is a %s, not a commit",  +		      sha1_to_hex(sha1), obj->type); +		return NULL; +	} +	return (struct commit *) obj; +} + +struct commit *lookup_commit_reference(unsigned char *sha1) +{ +	struct object *obj = parse_object(sha1); + +	if (!obj) +		return NULL; +	if (obj->type == tag_type) +		obj = ((struct tag *)obj)->tagged; +	return check_commit(obj, sha1); +} +  struct commit *lookup_commit(unsigned char *sha1)  {  	struct object *obj = lookup_object(sha1); @@ -15,12 +37,7 @@ struct commit *lookup_commit(unsigned char *sha1)  		ret->object.type = commit_type;  		return ret;  	} -	if (obj->type != commit_type) { -		error("Object %s is a %s, not a commit",  -		      sha1_to_hex(sha1), obj->type); -		return NULL; -	} -	return (struct commit *) obj; +	return check_commit(obj, sha1);  }  static unsigned long parse_commit_date(const char *buf) | 
