diff options
| author | Vicent Marti <tanoku@gmail.com> | 2013-05-30 03:47:10 +0200 |
|---|---|---|
| committer | Vicent Marti <tanoku@gmail.com> | 2013-05-30 03:47:10 +0200 |
| commit | 4e6e2ff26f5a04a4628aa0d81e5d5d73acf28ec4 (patch) | |
| tree | 9a6d20bb0d7e8b390bbb0a5b0a67a493ea778fd6 /tests-clar | |
| parent | ec24e542969f9d49e41e4c2cb3eac2259b1818c2 (diff) | |
| download | libgit2-4e6e2ff26f5a04a4628aa0d81e5d5d73acf28ec4.tar.gz | |
...Aaaand this works
Diffstat (limited to 'tests-clar')
| -rw-r--r-- | tests-clar/refdb/testdb.c | 182 | ||||
| -rw-r--r-- | tests-clar/refdb/testdb.h | 9 |
2 files changed, 0 insertions, 191 deletions
diff --git a/tests-clar/refdb/testdb.c b/tests-clar/refdb/testdb.c deleted file mode 100644 index 6509ae9a2..000000000 --- a/tests-clar/refdb/testdb.c +++ /dev/null @@ -1,182 +0,0 @@ -#include "vector.h" -#include "util.h" -#include "testdb.h" - -typedef struct refdb_test_backend { - git_refdb_backend parent; - - git_repository *repo; - git_vector refs; -} refdb_test_backend; - -typedef struct refdb_test_entry { - char *name; - git_ref_t type; - - union { - git_oid oid; - char *symbolic; - } target; -} refdb_test_entry; - -static int ref_name_cmp(const void *a, const void *b) -{ - return strcmp(git_reference_name((git_reference *)a), - git_reference_name((git_reference *)b)); -} - -static int refdb_test_backend__exists( - int *exists, - git_refdb_backend *_backend, - const char *ref_name) -{ - refdb_test_backend *backend; - refdb_test_entry *entry; - size_t i; - - assert(_backend); - backend = (refdb_test_backend *)_backend; - - *exists = 0; - - git_vector_foreach(&backend->refs, i, entry) { - if (strcmp(entry->name, ref_name) == 0) { - *exists = 1; - break; - } - } - - return 0; -} - -static int refdb_test_backend__write( - git_refdb_backend *_backend, - const git_reference *ref) -{ - refdb_test_backend *backend; - refdb_test_entry *entry; - - assert(_backend); - backend = (refdb_test_backend *)_backend; - - entry = git__calloc(1, sizeof(refdb_test_entry)); - GITERR_CHECK_ALLOC(entry); - - entry->name = git__strdup(git_reference_name(ref)); - GITERR_CHECK_ALLOC(entry->name); - - entry->type = git_reference_type(ref); - - if (entry->type == GIT_REF_OID) - git_oid_cpy(&entry->target.oid, git_reference_target(ref)); - else { - entry->target.symbolic = git__strdup(git_reference_symbolic_target(ref)); - GITERR_CHECK_ALLOC(entry->target.symbolic); - } - - git_vector_insert(&backend->refs, entry); - - return 0; -} - -static int refdb_test_backend__lookup( - git_reference **out, - git_refdb_backend *_backend, - const char *ref_name) -{ - refdb_test_backend *backend; - refdb_test_entry *entry; - size_t i; - - assert(_backend); - backend = (refdb_test_backend *)_backend; - - git_vector_foreach(&backend->refs, i, entry) { - if (strcmp(entry->name, ref_name) == 0) { - - if (entry->type == GIT_REF_OID) { - *out = git_reference__alloc(ref_name, - &entry->target.oid, NULL); - } else if (entry->type == GIT_REF_SYMBOLIC) { - *out = git_reference__alloc_symbolic(ref_name, - entry->target.symbolic); - } - - if (*out == NULL) - return -1; - - return 0; - } - } - - return GIT_ENOTFOUND; -} - -static void refdb_test_entry_free(refdb_test_entry *entry) -{ - if (entry->type == GIT_REF_SYMBOLIC) - git__free(entry->target.symbolic); - - git__free(entry->name); - git__free(entry); -} - -static int refdb_test_backend__delete( - git_refdb_backend *_backend, - const git_reference *ref) -{ - refdb_test_backend *backend; - refdb_test_entry *entry; - size_t i; - - assert(_backend); - backend = (refdb_test_backend *)_backend; - - git_vector_foreach(&backend->refs, i, entry) { - if (strcmp(entry->name, git_reference_name(ref)) == 0) { - git_vector_remove(&backend->refs, i); - refdb_test_entry_free(entry); - } - } - - return GIT_ENOTFOUND; -} - -static void refdb_test_backend__free(git_refdb_backend *_backend) -{ - refdb_test_backend *backend; - refdb_test_entry *entry; - size_t i; - - assert(_backend); - backend = (refdb_test_backend *)_backend; - - git_vector_foreach(&backend->refs, i, entry) - refdb_test_entry_free(entry); - - git_vector_free(&backend->refs); - git__free(backend); -} - -int refdb_backend_test( - git_refdb_backend **backend_out, - git_repository *repo) -{ - refdb_test_backend *backend; - - backend = git__calloc(1, sizeof(refdb_test_backend)); - GITERR_CHECK_ALLOC(backend); - - git_vector_init(&backend->refs, 0, ref_name_cmp); - - backend->repo = repo; - - backend->parent.exists = &refdb_test_backend__exists; - backend->parent.lookup = &refdb_test_backend__lookup; - backend->parent.write = &refdb_test_backend__write; - backend->parent.delete = &refdb_test_backend__delete; - backend->parent.free = &refdb_test_backend__free; - - *backend_out = (git_refdb_backend *)backend; - return 0; -} diff --git a/tests-clar/refdb/testdb.h b/tests-clar/refdb/testdb.h deleted file mode 100644 index a0d1bbc48..000000000 --- a/tests-clar/refdb/testdb.h +++ /dev/null @@ -1,9 +0,0 @@ -#include <git2/errors.h> -#include <git2/repository.h> -#include <git2/refdb.h> -#include <git2/sys/refs.h> -#include <git2/sys/refdb_backend.h> - -int refdb_backend_test( - git_refdb_backend **backend_out, - git_repository *repo); |
