From 55f6f21b7dd5a177e2cc60c1054b438c05ed8f14 Mon Sep 17 00:00:00 2001 From: Ben Straub Date: Thu, 29 Nov 2012 19:59:18 -0800 Subject: [PATCH] Deploy versioned git_odb_backend structure --- src/odb.c | 15 +++++++++++++++ src/odb_loose.c | 1 + src/odb_pack.c | 2 ++ tests-clar/odb/sorting.c | 4 ++-- 4 files changed, 20 insertions(+), 2 deletions(-) diff --git a/src/odb.c b/src/odb.c index 63b68284a..e35e4caca 100644 --- a/src/odb.c +++ b/src/odb.c @@ -363,12 +363,27 @@ int git_odb_new(git_odb **out) return 0; } +static bool backend_has_valid_version(git_odb_backend *backend) +{ + if (!backend) + return true; + + if (backend->version > 0 && backend->version <= GIT_ODB_BACKEND_VERSION) + return true; + + giterr_set(GITERR_INVALID, "Invalid version %d on git_odb_backend", backend->version); + return false; +} + static int add_backend_internal(git_odb *odb, git_odb_backend *backend, int priority, int is_alternate) { backend_internal *internal; assert(odb && backend); + if (!backend_has_valid_version(backend)) + return -1; + /* Check if the backend is already owned by another ODB */ assert(!backend->odb || backend->odb == odb); diff --git a/src/odb_loose.c b/src/odb_loose.c index e2f1aec32..df86d903e 100644 --- a/src/odb_loose.c +++ b/src/odb_loose.c @@ -915,6 +915,7 @@ int git_odb_backend_loose( backend = git__calloc(1, sizeof(loose_backend)); GITERR_CHECK_ALLOC(backend); + backend->parent.version = GIT_ODB_BACKEND_VERSION; backend->objects_dir = git__strdup(objects_dir); GITERR_CHECK_ALLOC(backend->objects_dir); diff --git a/src/odb_pack.c b/src/odb_pack.c index 35bf1580d..41789e4ec 100644 --- a/src/odb_pack.c +++ b/src/odb_pack.c @@ -570,6 +570,7 @@ int git_odb_backend_one_pack(git_odb_backend **backend_out, const char *idx) backend = git__calloc(1, sizeof(struct pack_backend)); GITERR_CHECK_ALLOC(backend); + backend->parent.version = GIT_ODB_BACKEND_VERSION; if (git_vector_init(&backend->packs, 1, NULL) < 0) goto on_error; @@ -602,6 +603,7 @@ int git_odb_backend_pack(git_odb_backend **backend_out, const char *objects_dir) backend = git__calloc(1, sizeof(struct pack_backend)); GITERR_CHECK_ALLOC(backend); + backend->parent.version = GIT_ODB_BACKEND_VERSION; if (git_vector_init(&backend->packs, 8, packfile_sort__cb) < 0 || git_buf_joinpath(&path, objects_dir, "pack") < 0) diff --git a/tests-clar/odb/sorting.c b/tests-clar/odb/sorting.c index bf64f6af4..b4f9e44bc 100644 --- a/tests-clar/odb/sorting.c +++ b/tests-clar/odb/sorting.c @@ -11,11 +11,11 @@ static git_odb_backend *new_backend(int position) { fake_backend *b; - b = git__malloc(sizeof(fake_backend)); + b = git__calloc(1, sizeof(fake_backend)); if (b == NULL) return NULL; - memset(b, 0x0, sizeof(fake_backend)); + b->base.version = GIT_ODB_BACKEND_VERSION; b->position = position; return (git_odb_backend *)b; }