aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorKeisuke Kuroynagi <ksk@google.com>2013-06-21 08:15:05 +0000
committerAndroid (Google) Code Review <android-gerrit@google.com>2013-06-21 08:15:05 +0000
commit21dfdcdba841f8866041cb0261feac907d6e686b (patch)
tree5ebe0075852fe32324930e0b70b52a9b31d6ea2a
parente105fdfaeaf5a434661518b4c78f2c198f2169ae (diff)
parent8a914a66e864ed5a1c787d5365b7eb36ddae6071 (diff)
downloadlatinime-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.h11
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);