diff options
author | 2012-09-21 13:35:38 -0700 | |
---|---|---|
committer | 2012-09-21 13:35:38 -0700 | |
commit | 8cbf6259c42c73b21f3fc9dbee04f9d236572781 (patch) | |
tree | a95de0f206f27aaf9d9afb5b4ff3308a921c0ab7 /java/src/com/android/inputmethod/latin/makedict/BinaryDictIOUtils.java | |
parent | 207cb0da768e170ba8c50bfceb876645b26e949a (diff) | |
parent | 66597f5e5f3249f418665c1990fb539d2f5565d5 (diff) | |
download | latinime-8cbf6259c42c73b21f3fc9dbee04f9d236572781.tar.gz latinime-8cbf6259c42c73b21f3fc9dbee04f9d236572781.tar.xz latinime-8cbf6259c42c73b21f3fc9dbee04f9d236572781.zip |
am 66597f5e: Add deleteWord.
* commit '66597f5e5f3249f418665c1990fb539d2f5565d5':
Add deleteWord.
Diffstat (limited to 'java/src/com/android/inputmethod/latin/makedict/BinaryDictIOUtils.java')
-rw-r--r-- | java/src/com/android/inputmethod/latin/makedict/BinaryDictIOUtils.java | 22 |
1 files changed, 22 insertions, 0 deletions
diff --git a/java/src/com/android/inputmethod/latin/makedict/BinaryDictIOUtils.java b/java/src/com/android/inputmethod/latin/makedict/BinaryDictIOUtils.java index 406071071..397532933 100644 --- a/java/src/com/android/inputmethod/latin/makedict/BinaryDictIOUtils.java +++ b/java/src/com/android/inputmethod/latin/makedict/BinaryDictIOUtils.java @@ -201,4 +201,26 @@ public class BinaryDictIOUtils { } return FormatSpec.NOT_VALID_WORD; } + + /** + * Delete the word from the binary file. + * + * @param buffer the buffer to write. + * @param word the word we delete + * @throws IOException + * @throws UnsupportedFormatException + */ + public static void deleteWord(final FusionDictionaryBufferInterface buffer, + final String word) throws IOException, UnsupportedFormatException { + buffer.position(0); + final FileHeader header = BinaryDictInputOutput.readHeader(buffer); + final int wordPosition = getTerminalPosition(buffer, word); + if (wordPosition == FormatSpec.NOT_VALID_WORD) return; + + buffer.position(wordPosition); + final int flags = buffer.readUnsignedByte(); + final int newFlags = flags ^ FormatSpec.FLAG_IS_TERMINAL; + buffer.position(wordPosition); + buffer.put((byte)newFlags); + } } |