{
a = b = i;
CU_ASSERT_EQUAL(a, unzigzag64(zigzag64(a)));
- CU_ASSERT_EQUAL(b, unzigzag32(zigzag64(b)));
+ CU_ASSERT_EQUAL(b, unzigzag32(zigzag32(b)));
a = b = -1 * i;
CU_ASSERT_EQUAL(a, unzigzag64(zigzag64(a)));
- CU_ASSERT_EQUAL(b, unzigzag32(zigzag64(b)));
+ CU_ASSERT_EQUAL(b, unzigzag32(zigzag32(b)));
}
+ //8
+ CU_ASSERT_EQUAL(-INT8_MAX, unzigzag8(zigzag8(-INT8_MAX)));
+ CU_ASSERT_EQUAL(INT8_MAX, unzigzag8(zigzag8(INT8_MAX)));
+ CU_ASSERT_EQUAL(0, unzigzag8(zigzag8(0)));
+
+ //32
+ CU_ASSERT_EQUAL(-INT32_MAX, unzigzag32(zigzag32(-INT32_MAX)));
+ CU_ASSERT_EQUAL(INT32_MAX, unzigzag32(zigzag32(INT32_MAX)));
+ CU_ASSERT_EQUAL(0, unzigzag32(zigzag32(0)));
+
+ //64
+ CU_ASSERT_EQUAL(-INT64_MAX, unzigzag64(zigzag64(-INT64_MAX)));
+ CU_ASSERT_EQUAL(INT64_MAX, unzigzag64(zigzag64(INT64_MAX)));
+ CU_ASSERT_EQUAL(0, unzigzag64(zigzag64(0)));
}
uint64_t zigzag64(int64_t val)
{
- return (val << 1) ^ (val >> 63);
+ return val >= 0 ?
+ ((uint64_t)val) << 1 :
+ ((((uint64_t)(-1 - val)) << 1) | 0x01);
}
uint32_t zigzag32(int32_t val)
{
- return (val << 1) ^ (val >> 31);
+ return val >= 0 ?
+ ((uint32_t)val) << 1 :
+ ((((uint32_t)(-1 - val)) << 1) | 0x01);
}
uint8_t zigzag8(int8_t val)
{
- return (val << 1) ^ (val >> 7);
+ return val >= 0 ?
+ ((uint8_t)val) << 1 :
+ ((((uint8_t)(-1 - val)) << 1) | 0x01);
}
int64_t unzigzag64(uint64_t val)
{
- if ( val & 0x01 )
- return -1 * (int64_t)((val+1) >> 1);
- else
- return (int64_t)(val >> 1);
+ return !(val & 0x01) ?
+ ((int64_t)(val >> 1)) :
+ (-1 * (int64_t)((val+1) >> 1));
}
int32_t unzigzag32(uint32_t val)
{
- if ( val & 0x01 )
- return -1 * (int32_t)((val+1) >> 1);
- else
- return (int32_t)(val >> 1);
+ return !(val & 0x01) ?
+ ((int32_t)(val >> 1)) :
+ (-1 * (int32_t)((val+1) >> 1));
}
int8_t unzigzag8(uint8_t val)
{
- if ( val & 0x01 )
- return -1 * (int8_t)((val+1) >> 1);
- else
- return (int8_t)(val >> 1);
+ return !(val & 0x01) ?
+ ((int8_t)(val >> 1)) :
+ (-1 * (int8_t)((val+1) >> 1));
}
size_t varint_size(const uint8_t *the_start, const uint8_t *the_end);
+/* Support from -INT{8,32,64}_MAX to INT{8,32,64}_MAX),
+ * e.g INT8_MIN is not supported in zigzag8 */
uint64_t zigzag64(int64_t val);
uint32_t zigzag32(int32_t val);
uint8_t zigzag8(int8_t val);