summaryrefslogtreecommitdiff
path: root/src/pack.c
diff options
context:
space:
mode:
authorCarlos Martín Nieto <carlos@cmartin.tk>2011-07-28 11:45:46 +0200
committerCarlos Martín Nieto <carlos@cmartin.tk>2011-08-02 21:42:03 +0200
commitb5b474dd0de88c0decd1bf6f4a4b202c8081bf43 (patch)
tree099cd324fdb774c89e352ae1a9394406c83b1d44 /src/pack.c
parenta070f152bdeaeef61e7b0624231fe1d946b0043e (diff)
downloadlibgit2-b5b474dd0de88c0decd1bf6f4a4b202c8081bf43.tar.gz
Modify the given offset in git_packfile_unpack
The callers immediately throw away the offset, so we don't need any logical changes in any of them. This will be useful for the indexer, as it does need to know where the compressed data ends. Signed-off-by: Carlos Martín Nieto <carlos@cmartin.tk>
Diffstat (limited to 'src/pack.c')
-rw-r--r--src/pack.c35
1 files changed, 22 insertions, 13 deletions
diff --git a/src/pack.c b/src/pack.c
index dca1903bd..f7bad2f80 100644
--- a/src/pack.c
+++ b/src/pack.c
@@ -38,7 +38,7 @@ int packfile_unpack_compressed(
git_rawobj *obj,
struct git_pack_file *p,
git_mwindow **w_curs,
- off_t curpos,
+ off_t *curpos,
size_t size,
git_otype type);
@@ -286,7 +286,7 @@ static int packfile_unpack_delta(
git_rawobj *obj,
struct git_pack_file *p,
git_mwindow **w_curs,
- off_t curpos,
+ off_t *curpos,
size_t delta_size,
git_otype delta_type,
off_t obj_offset)
@@ -295,12 +295,12 @@ static int packfile_unpack_delta(
git_rawobj base, delta;
int error;
- base_offset = get_delta_base(p, w_curs, &curpos, delta_type, obj_offset);
+ base_offset = get_delta_base(p, w_curs, curpos, delta_type, obj_offset);
if (base_offset == 0)
return git__throw(GIT_EOBJCORRUPTED, "Delta offset is zero");
git_mwindow_close(w_curs);
- error = git_packfile_unpack(&base, p, base_offset);
+ error = git_packfile_unpack(&base, p, &base_offset);
/*
* TODO: git.git tries to load the base from other packfiles
@@ -333,10 +333,10 @@ static int packfile_unpack_delta(
int git_packfile_unpack(
git_rawobj *obj,
struct git_pack_file *p,
- off_t obj_offset)
+ off_t *obj_offset)
{
git_mwindow *w_curs = NULL;
- off_t curpos = obj_offset;
+ off_t curpos = *obj_offset;
int error;
size_t size = 0;
@@ -358,8 +358,8 @@ int git_packfile_unpack(
case GIT_OBJ_OFS_DELTA:
case GIT_OBJ_REF_DELTA:
error = packfile_unpack_delta(
- obj, p, &w_curs, curpos,
- size, type, obj_offset);
+ obj, p, &w_curs, &curpos,
+ size, type, *obj_offset);
break;
case GIT_OBJ_COMMIT:
@@ -367,7 +367,7 @@ int git_packfile_unpack(
case GIT_OBJ_BLOB:
case GIT_OBJ_TAG:
error = packfile_unpack_compressed(
- obj, p, &w_curs, curpos,
+ obj, p, &w_curs, &curpos,
size, type);
break;
@@ -377,14 +377,19 @@ int git_packfile_unpack(
}
git_mwindow_close(&w_curs);
- return error == GIT_SUCCESS ? GIT_SUCCESS : git__rethrow(error, "Failed to unpack packfile");
+
+ if (error < GIT_SUCCESS)
+ return git__rethrow(error, "Failed to unpack object");
+
+ *obj_offset = curpos;
+ return GIT_SUCCESS;
}
int packfile_unpack_compressed(
git_rawobj *obj,
struct git_pack_file *p,
git_mwindow **w_curs,
- off_t curpos,
+ off_t *curpos,
size_t size,
git_otype type)
{
@@ -406,14 +411,14 @@ int packfile_unpack_compressed(
}
do {
- in = pack_window_open(p, w_curs, curpos, &stream.avail_in);
+ in = pack_window_open(p, w_curs, *curpos, &stream.avail_in);
stream.next_in = in;
st = inflate(&stream, Z_FINISH);
if (!stream.avail_out)
break; /* the payload is larger than it should be */
- curpos += stream.next_in - in;
+ *curpos += stream.next_in - in;
} while (st == Z_OK || st == Z_BUF_ERROR);
inflateEnd(&stream);
@@ -429,6 +434,10 @@ int packfile_unpack_compressed(
return GIT_SUCCESS;
}
+/*
+ * curpos is where the data starts, delta_obj_offset is the where the
+ * header starts
+ */
off_t get_delta_base(
struct git_pack_file *p,
git_mwindow **w_curs,