diff options
author | 2013-06-21 08:15:05 +0000 | |
---|---|---|
committer | 2013-06-21 08:15:05 +0000 | |
commit | 21dfdcdba841f8866041cb0261feac907d6e686b (patch) | |
tree | 5ebe0075852fe32324930e0b70b52a9b31d6ea2a | |
parent | e105fdfaeaf5a434661518b4c78f2c198f2169ae (diff) | |
parent | 8a914a66e864ed5a1c787d5365b7eb36ddae6071 (diff) | |
download | latinime-21dfdcdba841f8866041cb0261feac907d6e686b.tar.gz latinime-21dfdcdba841f8866041cb0261feac907d6e686b.tar.xz latinime-21dfdcdba841f8866041cb0261feac907d6e686b.zip |
Merge "Add ByteArrayUtils::readSignedInt24andAdvancePosition to read dynamic dictionaries."
-rw-r--r-- | native/jni/src/suggest/core/dictionary/byte_array_utils.h | 11 |
1 files changed, 11 insertions, 0 deletions
diff --git a/native/jni/src/suggest/core/dictionary/byte_array_utils.h b/native/jni/src/suggest/core/dictionary/byte_array_utils.h index d3321f624..daa822ffa 100644 --- a/native/jni/src/suggest/core/dictionary/byte_array_utils.h +++ b/native/jni/src/suggest/core/dictionary/byte_array_utils.h @@ -57,6 +57,17 @@ class ByteArrayUtils { return value; } + static AK_FORCE_INLINE int readSint24andAdvancePosition( + const uint8_t *const buffer, int *const pos) { + const uint8_t value = readUint8(buffer, *pos); + if (value < 0x80) { + return readUint24andAdvancePosition(buffer, pos); + } else { + (*pos)++; + return -(((value & 0x7F) << 16) ^ readUint16andAdvancePosition(buffer, pos)); + } + } + static AK_FORCE_INLINE uint32_t readUint24andAdvancePosition( const uint8_t *const buffer, int *const pos) { const uint32_t value = readUint24(buffer, *pos); |