diff options
| author | Vicent Marti <tanoku@gmail.com> | 2010-05-21 02:35:40 +0200 | 
|---|---|---|
| committer | Andreas Ericsson <ae@op5.se> | 2010-06-02 10:32:06 +0200 | 
| commit | 8add01539268300564482f854412cfe9839e980c (patch) | |
| tree | c620f25d7fb92598b819001c8265d0d324275546 /src/commit.c | |
| parent | 08d5d00056a7237bf6c60f85a6e72b7549cf9133 (diff) | |
| download | libgit2-8add01539268300564482f854412cfe9839e980c.tar.gz | |
Split git_commit_lookup into separate functions.
git_commit_lookup() now creates commit references
without loading them from the ODB.
git_commit_parse() creates a commit reference, loads
it and parses it from the ODB.
Signed-off-by: Vicent Marti <tanoku@gmail.com>
Signed-off-by: Andreas Ericsson <ae@op5.se>
Diffstat (limited to 'src/commit.c')
| -rw-r--r-- | src/commit.c | 68 | 
1 files changed, 49 insertions, 19 deletions
| diff --git a/src/commit.c b/src/commit.c index 8844825b8..fa33b5202 100644 --- a/src/commit.c +++ b/src/commit.c @@ -51,41 +51,71 @@ void git_commit_mark_uninteresting(git_commit *commit)  	}  } -git_commit *git_commit_lookup(git_revpool *pool, const git_oid *id) +git_commit *git_commit_parse(git_revpool *pool, const git_oid *id)  { -    git_obj commit_obj;      git_commit *commit = NULL; -    if (pool == NULL || pool->db == NULL) +    if ((commit = git_commit_lookup(pool, id)) == NULL)          return NULL; -    /* -     * TODO: check if the commit is already cached in the -     * revpool instead of loading it from the odb -     */ +    if (git_commit_parse_existing(commit) < 0) +        goto error_cleanup; -    if (git_odb_read(&commit_obj, pool->db, id) < 0) -        return NULL; +    return commit; + +error_cleanup: +    free(commit); +    return NULL; +} + +int git_commit_parse_existing(git_commit *commit) +{ +    git_obj commit_obj; + +    if (commit->parsed) +        return 0; + +    if (commit->pool == NULL || commit->pool->db == NULL) +        return -1; + +    if (git_odb_read(&commit_obj, commit->pool->db, &commit->id) < 0) +        return -1;      if (commit_obj.type != GIT_OBJ_COMMIT)          goto error_cleanup; +    if (git_commit__parse_buffer(commit, commit_obj.data, commit_obj.len) < 0) +        goto error_cleanup; + +    git_obj_close(&commit_obj); + +    return 0; + +error_cleanup: +    git_obj_close(&commit_obj); +    return -1; +} + +git_commit *git_commit_lookup(git_revpool *pool, const git_oid *id) +{ +    git_commit *commit = NULL; + +    if (pool == NULL || pool->db == NULL) +        return NULL; +      commit = git__malloc(sizeof(git_commit)); + +    if (commit == NULL) +        return NULL; +      memset(commit, 0x0, sizeof(git_commit));      git_oid_cpy(&commit->id, id);      commit->pool = pool; -    if (git_commit__parse_buffer(commit, commit_obj.data, commit_obj.len) < 0) -        goto error_cleanup; +    git_commit_list_insert(&pool->commits, commit);      return commit; - -error_cleanup: -    git_obj_close(&commit_obj); -    free(commit); - -    return NULL;  }  int git_commit__parse_time(time_t *commit_time, char *buffer, const char *buffer_end) @@ -111,8 +141,8 @@ int git_commit__parse_time(time_t *commit_time, char *buffer, const char *buffer  int git_commit__parse_oid(git_oid *oid, char **buffer_out, const char *buffer_end, const char *header)  { -    size_t sha_len = GIT_OID_HEXSZ; -    size_t header_len = strlen(header); +    const size_t sha_len = GIT_OID_HEXSZ; +    const size_t header_len = strlen(header);      char *buffer = *buffer_out; | 
