aboutsummaryrefslogtreecommitdiffstats
path: root/native/jni/src
diff options
context:
space:
mode:
authorKeisuke Kuroynagi <ksk@google.com>2013-07-02 18:39:56 +0900
committerKeisuke Kuroynagi <ksk@google.com>2013-07-02 18:39:56 +0900
commitf6aa9e9a1d8e98b00a53f18359153d1e487efe57 (patch)
tree79a0f42898e24763991b477efb1606571501ef3f /native/jni/src
parentb6f5d3e39d1f3073c4e7d75e9d4309112879dc6e (diff)
downloadlatinime-f6aa9e9a1d8e98b00a53f18359153d1e487efe57.tar.gz
latinime-f6aa9e9a1d8e98b00a53f18359153d1e487efe57.tar.xz
latinime-f6aa9e9a1d8e98b00a53f18359153d1e487efe57.zip
Fix: Reading invalid dictionary position.
Bug: 6669677 Change-Id: I3f4078aaa8cf72f3b366e7851457e9c753c0102f
Diffstat (limited to 'native/jni/src')
-rw-r--r--native/jni/src/suggest/core/dictionary/terminal_attributes.h9
1 files changed, 5 insertions, 4 deletions
diff --git a/native/jni/src/suggest/core/dictionary/terminal_attributes.h b/native/jni/src/suggest/core/dictionary/terminal_attributes.h
index cec47081e..a8520b1f1 100644
--- a/native/jni/src/suggest/core/dictionary/terminal_attributes.h
+++ b/native/jni/src/suggest/core/dictionary/terminal_attributes.h
@@ -76,12 +76,13 @@ class TerminalAttributes {
mNodeFlags(nodeFlags), mShortcutListSizePos(shortcutPos) {}
inline ShortcutIterator getShortcutIterator() const {
- // The size of the shortcuts is stored here so that the whole shortcut chunk can be
- // skipped quickly, so we ignore it.
int shortcutPos = mShortcutListSizePos;
- BinaryDictionaryTerminalAttributesReadingUtils::getShortcutListSizeAndForwardPointer(
- mBinaryDictionaryInfo, &shortcutPos);
const bool hasShortcutList = 0 != (mNodeFlags & BinaryFormat::FLAG_HAS_SHORTCUT_TARGETS);
+ if (hasShortcutList) {
+ BinaryDictionaryTerminalAttributesReadingUtils::getShortcutListSizeAndForwardPointer(
+ mBinaryDictionaryInfo, &shortcutPos);
+ }
+ // shortcutPos is never used if hasShortcutList is false.
return ShortcutIterator(mBinaryDictionaryInfo, shortcutPos, hasShortcutList);
}