#define PROTOTYPES 1
#define MD5Final vb__MD5_final
#define MD5Init vb__MD5Init
#define MD5Update vb__MD5Update
#include <stdlib.h>
#include "rfc1321/md5c-inl.h"
#include "hash.h"
void vb__hash_md5(const char *key, size_t key_length, unsigned char *result)
{
MD5_CTX ctx;
MD5Init(&ctx);
MD5Update(&ctx, (unsigned char *)key, (unsigned int)key_length);
MD5Final(result, &ctx);
}
void* vb__hash_md5_update(void *ctx, const char *key, size_t key_length)
{
if (ctx == NULL) {
ctx = calloc(1, sizeof(MD5_CTX));
MD5Init(ctx);
}
MD5Update(ctx, (unsigned char *)key, (unsigned int)key_length);
return ctx;
}
void vb__hash_md5_final(void *ctx, unsigned char *result)
{
if (ctx == NULL) {
return;
}
MD5Final(result, ctx);
free(ctx);
}
uint32_t vb__hash_ketama(const char *key, size_t key_length)
{
unsigned char digest[16];
vb__hash_md5(key, key_length, digest);
return (uint32_t) ( (digest[3] << 24)
|(digest[2] << 16)
|(digest[1] << 8)
| digest[0]);
}