mirror of
https://github.com/yarrick/iodine.git
synced 2024-11-24 00:59:19 +02:00
Added simple 5bits to 8 and reverse encoder, with test
This commit is contained in:
parent
9d8e9a7d18
commit
458b5af003
21
src/base32.c
21
src/base32.c
|
@ -70,6 +70,27 @@ base32_blksize_enc()
|
||||||
return BLKSIZE_ENC;
|
return BLKSIZE_ENC;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int
|
||||||
|
b32_5to8(int in)
|
||||||
|
{
|
||||||
|
return cb32[in & 31];
|
||||||
|
}
|
||||||
|
|
||||||
|
int
|
||||||
|
b32_8to5(int in)
|
||||||
|
{
|
||||||
|
int i;
|
||||||
|
int c;
|
||||||
|
if (!reverse_init) {
|
||||||
|
for (i = 0; i < 32; i++) {
|
||||||
|
c = cb32[i];
|
||||||
|
rev32[(int) c] = i;
|
||||||
|
}
|
||||||
|
reverse_init = 1;
|
||||||
|
}
|
||||||
|
return rev32[in];
|
||||||
|
}
|
||||||
|
|
||||||
static int
|
static int
|
||||||
base32_encode(char *buf, size_t *buflen, const void *data, size_t size)
|
base32_encode(char *buf, size_t *buflen, const void *data, size_t size)
|
||||||
{
|
{
|
||||||
|
|
|
@ -19,4 +19,6 @@
|
||||||
|
|
||||||
struct encoder *get_base32_encoder(void);
|
struct encoder *get_base32_encoder(void);
|
||||||
|
|
||||||
|
int b32_5to8(int);
|
||||||
|
int b32_8to5(int);
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -77,6 +77,18 @@ START_TEST(test_base32_decode)
|
||||||
}
|
}
|
||||||
END_TEST
|
END_TEST
|
||||||
|
|
||||||
|
START_TEST(test_base32_5to8_8to5)
|
||||||
|
{
|
||||||
|
int i;
|
||||||
|
int c;
|
||||||
|
|
||||||
|
for (i = 0; i < 32; i++) {
|
||||||
|
c = b32_5to8(i);
|
||||||
|
fail_unless(b32_8to5(c) == i);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
END_TEST
|
||||||
|
|
||||||
TCase *
|
TCase *
|
||||||
test_base32_create_tests()
|
test_base32_create_tests()
|
||||||
{
|
{
|
||||||
|
@ -85,6 +97,7 @@ test_base32_create_tests()
|
||||||
tc = tcase_create("Base32");
|
tc = tcase_create("Base32");
|
||||||
tcase_add_test(tc, test_base32_encode);
|
tcase_add_test(tc, test_base32_encode);
|
||||||
tcase_add_test(tc, test_base32_decode);
|
tcase_add_test(tc, test_base32_decode);
|
||||||
|
tcase_add_test(tc, test_base32_5to8_8to5);
|
||||||
|
|
||||||
return tc;
|
return tc;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue