aboutsummaryrefslogtreecommitdiffstats
path: root/java/src
diff options
context:
space:
mode:
authorTadashi G. Takaoka <takaoka@google.com>2014-02-05 09:32:12 +0000
committerAndroid (Google) Code Review <android-gerrit@google.com>2014-02-05 09:32:12 +0000
commit02a534d13f5e04173efdf10a509de8aa85d2d6a5 (patch)
tree34891ca20d3fb28482277151aab1753cb48dd9f7 /java/src
parent6e5dbdd5013258a33a3a9a3da0f0b74d3d9ed289 (diff)
parentf7d8b8fcbcfe137c1c25ca7ea5bd83f856f06b9e (diff)
downloadlatinime-02a534d13f5e04173efdf10a509de8aa85d2d6a5.tar.gz
latinime-02a534d13f5e04173efdf10a509de8aa85d2d6a5.tar.xz
latinime-02a534d13f5e04173efdf10a509de8aa85d2d6a5.zip
Merge "Treat a sole "|" as a special case of key label"
Diffstat (limited to 'java/src')
-rw-r--r--java/src/com/android/inputmethod/keyboard/internal/KeySpecParser.java6
1 files changed, 5 insertions, 1 deletions
diff --git a/java/src/com/android/inputmethod/keyboard/internal/KeySpecParser.java b/java/src/com/android/inputmethod/keyboard/internal/KeySpecParser.java
index 2a0dad678..2925a4b76 100644
--- a/java/src/com/android/inputmethod/keyboard/internal/KeySpecParser.java
+++ b/java/src/com/android/inputmethod/keyboard/internal/KeySpecParser.java
@@ -84,14 +84,18 @@ public final class KeySpecParser {
}
private static int indexOfLabelEnd(final String keySpec) {
+ final int length = keySpec.length();
if (keySpec.indexOf(BACKSLASH) < 0) {
final int labelEnd = keySpec.indexOf(VERTICAL_BAR);
if (labelEnd == 0) {
+ if (length == 1) {
+ // Treat a sole vertical bar as a special case of key label.
+ return -1;
+ }
throw new KeySpecParserError("Empty label");
}
return labelEnd;
}
- final int length = keySpec.length();
for (int pos = 0; pos < length; pos++) {
final char c = keySpec.charAt(pos);
if (c == BACKSLASH && pos + 1 < length) {