blob: 2e5b746fa05c3bbfe76fd7d7b038b4cc0fbeed75 (
plain) (
blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
|
#include "darwin/read.h"
bool read_leb128(void **ptr, void *end, bool is_signed, uint64_t *out) {
uint64_t result = 0;
uint8_t *p = *ptr;
uint8_t bit;
unsigned int shift = 0;
do {
if (p >= (uint8_t *) end)
return false;
bit = *p++;
uint64_t k = bit & 0x7f;
if (shift < sizeof(uint64_t) * 8)
result |= k << shift;
shift += 7;
} while (bit & 0x80);
if (is_signed && (bit & 0x40))
result |= ~((uint64_t) 0) << shift;
*ptr = p;
if (out)
*out = result;
return true;
}
|