Welcome to mirror list, hosted at ThFree Co, Russian Federation.

github.com/mono/libgit2.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorRussell Belfer <rb@github.com>2013-04-11 04:10:17 +0400
committerVicent Marti <tanoku@gmail.com>2013-04-22 18:50:51 +0400
commitbadd85a61354ef7b62c5f8e53d740738e5ef1e57 (patch)
tree553f006c1b237de2a57ad6416e80db4ac8e6cf1a /src/tree.c
parentee12272d170d6a9d60f13d6de6129f56bfb2fbf6 (diff)
Use git_odb_object_data/_size whereever possible
This uses the odb object accessors so we can change the internals more easily...
Diffstat (limited to 'src/tree.c')
-rw-r--r--src/tree.c14
1 files changed, 9 insertions, 5 deletions
diff --git a/src/tree.c b/src/tree.c
index 6ffb07c69..cc43b920c 100644
--- a/src/tree.c
+++ b/src/tree.c
@@ -371,7 +371,8 @@ static int tree_error(const char *str, const char *path)
return -1;
}
-static int tree_parse_buffer(git_tree *tree, const char *buffer, const char *buffer_end)
+static int tree_parse_buffer(
+ git_tree *tree, const char *buffer, const char *buffer_end)
{
if (git_vector_init(&tree->entries, DEFAULT_TREE_SIZE, entry_sort_cmp) < 0)
return -1;
@@ -418,10 +419,13 @@ static int tree_parse_buffer(git_tree *tree, const char *buffer, const char *buf
int git_tree__parse(git_tree *tree, git_odb_object *obj)
{
- assert(tree);
- return tree_parse_buffer(tree,
- (char *)obj->buffer,
- (char *)obj->buffer + obj->cached.size);
+ const char *buf;
+
+ assert(tree && obj);
+
+ buf = (const char *)git_odb_object_data(obj);
+
+ return tree_parse_buffer(tree, buf, buf + git_odb_object_size(obj));
}
static size_t find_next_dir(const char *dirname, git_index *index, size_t start)