diff options
author | Vicent Marti <tanoku@gmail.com> | 2012-11-01 20:15:53 +0100 |
---|---|---|
committer | Vicent Marti <tanoku@gmail.com> | 2012-11-01 20:17:10 +0100 |
commit | 276ea401b3a45c85e49182f39db00ca5447aa340 (patch) | |
tree | d13f81a763fb4be23044aa2210fcc81aadb095ff /src | |
parent | 8ff0f3250a62a128fb68ce3fae1719549a3fe47a (diff) | |
download | libgit2-276ea401b3a45c85e49182f39db00ca5447aa340.tar.gz |
index: Add git_index_write_tree
Diffstat (limited to 'src')
-rw-r--r-- | src/index.c | 52 | ||||
-rw-r--r-- | src/tree.c | 8 | ||||
-rw-r--r-- | src/tree.h | 6 |
3 files changed, 52 insertions, 14 deletions
diff --git a/src/index.c b/src/index.c index 8f684a34b..73fd40acf 100644 --- a/src/index.c +++ b/src/index.c @@ -264,8 +264,14 @@ int git_index_open(git_index **index_out, const char *index_path) index = git__calloc(1, sizeof(git_index)); GITERR_CHECK_ALLOC(index); - index->index_file_path = git__strdup(index_path); - GITERR_CHECK_ALLOC(index->index_file_path); + if (index_path != NULL) { + index->index_file_path = git__strdup(index_path); + GITERR_CHECK_ALLOC(index->index_file_path); + + /* Check if index file is stored on disk already */ + if (git_path_exists(index->index_file_path) == true) + index->on_disk = 1; + } if (git_vector_init(&index->entries, 32, index_cmp) < 0) return -1; @@ -275,13 +281,10 @@ int git_index_open(git_index **index_out, const char *index_path) index->entries_search_path = index_srch_path; index->reuc_search = reuc_srch; - /* Check if index file is stored on disk already */ - if (git_path_exists(index->index_file_path) == true) - index->on_disk = 1; - *index_out = index; GIT_REFCOUNT_INC(index); - return git_index_read(index); + + return (index_path != NULL) ? git_index_read(index) : 0; } static void index_free(git_index *index) @@ -394,7 +397,11 @@ int git_index_read(git_index *index) git_buf buffer = GIT_BUF_INIT; git_futils_filestamp stamp; - assert(index->index_file_path); + if (!index->index_file_path) { + giterr_set(GITERR_INDEX, + "Failed to read index: The index is in-memory only"); + return -1; + } if (!index->on_disk || git_path_exists(index->index_file_path) == false) { git_index_clear(index); @@ -426,6 +433,12 @@ int git_index_write(git_index *index) struct stat indexst; int error; + if (!index->index_file_path) { + giterr_set(GITERR_INDEX, + "Failed to write index: The index is in-memory only"); + return -1; + } + git_vector_sort(&index->entries); git_vector_sort(&index->reuc); @@ -449,6 +462,29 @@ int git_index_write(git_index *index) return 0; } +int git_index_write_tree(git_oid *oid, git_index *index) +{ + git_repository *repo; + + assert(oid && index); + + repo = (git_repository *)GIT_REFCOUNT_OWNER(index); + + if (repo == NULL) { + giterr_set(GITERR_INDEX, "Failed to write tree. " + "The index file is not backed up by an existing repository"); + return -1 + } + + return git_tree__write_index(oid, index, repo); +} + +int git_index_write_tree_to(git_oid *oid, git_index *index, git_repository *repo) +{ + assert(oid && index && repo); + return git_tree__write_index(oid, index, repo); +} + unsigned int git_index_entrycount(git_index *index) { assert(index); diff --git a/src/tree.c b/src/tree.c index 9ecefbb61..dd9f94869 100644 --- a/src/tree.c +++ b/src/tree.c @@ -491,16 +491,12 @@ on_error: return -1; } -int git_tree_create_fromindex(git_oid *oid, git_index *index) +int git_tree__write_index(git_oid *oid, git_index *index, git_repository *repo) { int ret; git_repository *repo; - repo = (git_repository *)GIT_REFCOUNT_OWNER(index); - - if (repo == NULL) - return tree_error("Failed to create tree. " - "The index file is not backed up by an existing repository"); + assert(oid && index && repo); if (index->tree != NULL && index->tree->entries >= 0) { git_oid_cpy(oid, &index->tree->oid); diff --git a/src/tree.h b/src/tree.h index 24b517ce3..b67c55202 100644 --- a/src/tree.h +++ b/src/tree.h @@ -47,6 +47,12 @@ int git_tree__parse(git_tree *tree, git_odb_object *obj); */ int git_tree__prefix_position(git_tree *tree, const char *prefix); + +/** + * Write a tree to the given repository + */ +int git_tree__write_index(git_oid *oid, git_index *index, git_repository *repo); + /** * Obsolete mode kept for compatibility reasons */ |