Skip to content

Commit

Permalink
hash: remove git_hash_init from internal api
Browse files Browse the repository at this point in the history
Along with that, fix indentation in tests-clar/object/raw/hash.c
  • Loading branch information
schu committed Feb 25, 2013
1 parent be225be commit efe7fad
Show file tree
Hide file tree
Showing 5 changed files with 79 additions and 81 deletions.
1 change: 0 additions & 1 deletion src/hash.h
Original file line number Diff line number Diff line change
Expand Up @@ -31,7 +31,6 @@ typedef struct {
size_t len;
} git_buf_vec;

int git_hash_init(git_hash_ctx *c);
int git_hash_update(git_hash_ctx *c, const void *data, size_t len);
int git_hash_final(git_oid *out, git_hash_ctx *c);

Expand Down
4 changes: 2 additions & 2 deletions src/hash/hash_generic.c
Original file line number Diff line number Diff line change
Expand Up @@ -221,7 +221,7 @@ static void hash__block(git_hash_ctx *ctx, const unsigned int *data)
ctx->H[4] += E;
}

int git_hash_init(git_hash_ctx *ctx)
int git_hash_ctx_init(git_hash_ctx *ctx)
{
ctx->size = 0;

Expand All @@ -232,7 +232,7 @@ int git_hash_init(git_hash_ctx *ctx)
ctx->H[3] = 0x10325476;
ctx->H[4] = 0xc3d2e1f0;

return 0;
return 0;
}

int git_hash_update(git_hash_ctx *ctx, const void *data, size_t len)
Expand Down
1 change: 0 additions & 1 deletion src/hash/hash_generic.h
Original file line number Diff line number Diff line change
Expand Up @@ -18,7 +18,6 @@ struct git_hash_ctx {

#define git_hash_global_init() 0
#define git_hash_global_shutdown() /* noop */
#define git_hash_ctx_init(ctx) git_hash_init(ctx)
#define git_hash_ctx_cleanup(ctx)

#endif /* INCLUDE_hash_generic_h__ */
4 changes: 2 additions & 2 deletions src/hash/hash_win32.c
Original file line number Diff line number Diff line change
Expand Up @@ -134,7 +134,7 @@ GIT_INLINE(int) hash_ctx_cryptoapi_init(git_hash_ctx *ctx)
ctx->type = CRYPTOAPI;
ctx->prov = &hash_prov;

return git_hash_init(ctx);
return git_hash_ctx_init(ctx);
}

GIT_INLINE(int) hash_cryptoapi_init(git_hash_ctx *ctx)
Expand Down Expand Up @@ -262,7 +262,7 @@ int git_hash_ctx_init(git_hash_ctx *ctx)
return (hash_prov.type == CNG) ? hash_ctx_cng_init(ctx) : hash_ctx_cryptoapi_init(ctx);
}

int git_hash_init(git_hash_ctx *ctx)
int git_hash_ctx_init(git_hash_ctx *ctx)
{
assert(ctx && ctx->type);
return (ctx->type == CNG) ? hash_cng_init(ctx) : hash_cryptoapi_init(ctx);
Expand Down
150 changes: 75 additions & 75 deletions tests-clar/object/raw/hash.c
Original file line number Diff line number Diff line change
Expand Up @@ -8,11 +8,11 @@

static void hash_object_pass(git_oid *oid, git_rawobj *obj)
{
cl_git_pass(git_odb_hash(oid, obj->data, obj->len, obj->type));
cl_git_pass(git_odb_hash(oid, obj->data, obj->len, obj->type));
}
static void hash_object_fail(git_oid *oid, git_rawobj *obj)
{
cl_git_fail(git_odb_hash(oid, obj->data, obj->len, obj->type));
cl_git_fail(git_odb_hash(oid, obj->data, obj->len, obj->type));
}

static char *hello_id = "22596363b3de40b06f981fb85d82312e8c0ed511";
Expand All @@ -23,144 +23,144 @@ static char *bye_text = "bye world\n";

void test_object_raw_hash__hash_by_blocks(void)
{
git_hash_ctx ctx;
git_oid id1, id2;
git_hash_ctx ctx;
git_oid id1, id2;

cl_git_pass(git_hash_ctx_init(&ctx));

/* should already be init'd */
cl_git_pass(git_hash_update(&ctx, hello_text, strlen(hello_text)));
cl_git_pass(git_hash_final(&id2, &ctx));
cl_git_pass(git_oid_fromstr(&id1, hello_id));
cl_assert(git_oid_cmp(&id1, &id2) == 0);
cl_git_pass(git_hash_update(&ctx, hello_text, strlen(hello_text)));
cl_git_pass(git_hash_final(&id2, &ctx));
cl_git_pass(git_oid_fromstr(&id1, hello_id));
cl_assert(git_oid_cmp(&id1, &id2) == 0);

/* reinit should permit reuse */
cl_git_pass(git_hash_init(&ctx));
cl_git_pass(git_hash_update(&ctx, bye_text, strlen(bye_text)));
cl_git_pass(git_hash_final(&id2, &ctx));
cl_git_pass(git_oid_fromstr(&id1, bye_id));
cl_assert(git_oid_cmp(&id1, &id2) == 0);
cl_git_pass(git_hash_ctx_init(&ctx));
cl_git_pass(git_hash_update(&ctx, bye_text, strlen(bye_text)));
cl_git_pass(git_hash_final(&id2, &ctx));
cl_git_pass(git_oid_fromstr(&id1, bye_id));
cl_assert(git_oid_cmp(&id1, &id2) == 0);

git_hash_ctx_cleanup(&ctx);
git_hash_ctx_cleanup(&ctx);
}

void test_object_raw_hash__hash_buffer_in_single_call(void)
{
git_oid id1, id2;
git_oid id1, id2;

cl_git_pass(git_oid_fromstr(&id1, hello_id));
git_hash_buf(&id2, hello_text, strlen(hello_text));
cl_assert(git_oid_cmp(&id1, &id2) == 0);
cl_git_pass(git_oid_fromstr(&id1, hello_id));
git_hash_buf(&id2, hello_text, strlen(hello_text));
cl_assert(git_oid_cmp(&id1, &id2) == 0);
}

void test_object_raw_hash__hash_vector(void)
{
git_oid id1, id2;
git_buf_vec vec[2];
git_oid id1, id2;
git_buf_vec vec[2];

cl_git_pass(git_oid_fromstr(&id1, hello_id));
cl_git_pass(git_oid_fromstr(&id1, hello_id));

vec[0].data = hello_text;
vec[0].len = 4;
vec[1].data = hello_text+4;
vec[1].len = strlen(hello_text)-4;
vec[0].data = hello_text;
vec[0].len = 4;
vec[1].data = hello_text+4;
vec[1].len = strlen(hello_text)-4;

git_hash_vec(&id2, vec, 2);
git_hash_vec(&id2, vec, 2);

cl_assert(git_oid_cmp(&id1, &id2) == 0);
cl_assert(git_oid_cmp(&id1, &id2) == 0);
}

void test_object_raw_hash__hash_junk_data(void)
{
git_oid id, id_zero;
git_oid id, id_zero;

cl_git_pass(git_oid_fromstr(&id_zero, zero_id));
cl_git_pass(git_oid_fromstr(&id_zero, zero_id));

/* invalid types: */
junk_obj.data = some_data;
hash_object_fail(&id, &junk_obj);
/* invalid types: */
junk_obj.data = some_data;
hash_object_fail(&id, &junk_obj);

junk_obj.type = GIT_OBJ__EXT1;
hash_object_fail(&id, &junk_obj);
junk_obj.type = GIT_OBJ__EXT1;
hash_object_fail(&id, &junk_obj);

junk_obj.type = GIT_OBJ__EXT2;
hash_object_fail(&id, &junk_obj);
junk_obj.type = GIT_OBJ__EXT2;
hash_object_fail(&id, &junk_obj);

junk_obj.type = GIT_OBJ_OFS_DELTA;
hash_object_fail(&id, &junk_obj);
junk_obj.type = GIT_OBJ_OFS_DELTA;
hash_object_fail(&id, &junk_obj);

junk_obj.type = GIT_OBJ_REF_DELTA;
hash_object_fail(&id, &junk_obj);
junk_obj.type = GIT_OBJ_REF_DELTA;
hash_object_fail(&id, &junk_obj);

/* data can be NULL only if len is zero: */
junk_obj.type = GIT_OBJ_BLOB;
junk_obj.data = NULL;
hash_object_pass(&id, &junk_obj);
cl_assert(git_oid_cmp(&id, &id_zero) == 0);
/* data can be NULL only if len is zero: */
junk_obj.type = GIT_OBJ_BLOB;
junk_obj.data = NULL;
hash_object_pass(&id, &junk_obj);
cl_assert(git_oid_cmp(&id, &id_zero) == 0);

junk_obj.len = 1;
hash_object_fail(&id, &junk_obj);
junk_obj.len = 1;
hash_object_fail(&id, &junk_obj);
}

void test_object_raw_hash__hash_commit_object(void)
{
git_oid id1, id2;
git_oid id1, id2;

cl_git_pass(git_oid_fromstr(&id1, commit_id));
hash_object_pass(&id2, &commit_obj);
cl_assert(git_oid_cmp(&id1, &id2) == 0);
cl_git_pass(git_oid_fromstr(&id1, commit_id));
hash_object_pass(&id2, &commit_obj);
cl_assert(git_oid_cmp(&id1, &id2) == 0);
}

void test_object_raw_hash__hash_tree_object(void)
{
git_oid id1, id2;
git_oid id1, id2;

cl_git_pass(git_oid_fromstr(&id1, tree_id));
hash_object_pass(&id2, &tree_obj);
cl_assert(git_oid_cmp(&id1, &id2) == 0);
cl_git_pass(git_oid_fromstr(&id1, tree_id));
hash_object_pass(&id2, &tree_obj);
cl_assert(git_oid_cmp(&id1, &id2) == 0);
}

void test_object_raw_hash__hash_tag_object(void)
{
git_oid id1, id2;
git_oid id1, id2;

cl_git_pass(git_oid_fromstr(&id1, tag_id));
hash_object_pass(&id2, &tag_obj);
cl_assert(git_oid_cmp(&id1, &id2) == 0);
cl_git_pass(git_oid_fromstr(&id1, tag_id));
hash_object_pass(&id2, &tag_obj);
cl_assert(git_oid_cmp(&id1, &id2) == 0);
}

void test_object_raw_hash__hash_zero_length_object(void)
{
git_oid id1, id2;
git_oid id1, id2;

cl_git_pass(git_oid_fromstr(&id1, zero_id));
hash_object_pass(&id2, &zero_obj);
cl_assert(git_oid_cmp(&id1, &id2) == 0);
cl_git_pass(git_oid_fromstr(&id1, zero_id));
hash_object_pass(&id2, &zero_obj);
cl_assert(git_oid_cmp(&id1, &id2) == 0);
}

void test_object_raw_hash__hash_one_byte_object(void)
{
git_oid id1, id2;
git_oid id1, id2;

cl_git_pass(git_oid_fromstr(&id1, one_id));
hash_object_pass(&id2, &one_obj);
cl_assert(git_oid_cmp(&id1, &id2) == 0);
cl_git_pass(git_oid_fromstr(&id1, one_id));
hash_object_pass(&id2, &one_obj);
cl_assert(git_oid_cmp(&id1, &id2) == 0);
}

void test_object_raw_hash__hash_two_byte_object(void)
{
git_oid id1, id2;
git_oid id1, id2;

cl_git_pass(git_oid_fromstr(&id1, two_id));
hash_object_pass(&id2, &two_obj);
cl_assert(git_oid_cmp(&id1, &id2) == 0);
cl_git_pass(git_oid_fromstr(&id1, two_id));
hash_object_pass(&id2, &two_obj);
cl_assert(git_oid_cmp(&id1, &id2) == 0);
}

void test_object_raw_hash__hash_multi_byte_object(void)
{
git_oid id1, id2;
git_oid id1, id2;

cl_git_pass(git_oid_fromstr(&id1, some_id));
hash_object_pass(&id2, &some_obj);
cl_assert(git_oid_cmp(&id1, &id2) == 0);
cl_git_pass(git_oid_fromstr(&id1, some_id));
hash_object_pass(&id2, &some_obj);
cl_assert(git_oid_cmp(&id1, &id2) == 0);
}

0 comments on commit efe7fad

Please sign in to comment.