am aaf864db
: Merge "Separate header class from FormatSpec."
* commit 'aaf864db7b978461f16acfce972c38dea207afd9': Separate header class from FormatSpec.
This commit is contained in:
commit
1222a61166
18 changed files with 141 additions and 126 deletions
|
@ -22,8 +22,8 @@ import android.content.res.AssetFileDescriptor;
|
||||||
import android.util.Log;
|
import android.util.Log;
|
||||||
|
|
||||||
import com.android.inputmethod.latin.makedict.DictDecoder;
|
import com.android.inputmethod.latin.makedict.DictDecoder;
|
||||||
|
import com.android.inputmethod.latin.makedict.DictionaryHeader;
|
||||||
import com.android.inputmethod.latin.makedict.FormatSpec;
|
import com.android.inputmethod.latin.makedict.FormatSpec;
|
||||||
import com.android.inputmethod.latin.makedict.FormatSpec.FileHeader;
|
|
||||||
import com.android.inputmethod.latin.makedict.UnsupportedFormatException;
|
import com.android.inputmethod.latin.makedict.UnsupportedFormatException;
|
||||||
import com.android.inputmethod.latin.utils.CollectionUtils;
|
import com.android.inputmethod.latin.utils.CollectionUtils;
|
||||||
import com.android.inputmethod.latin.utils.DictionaryInfoUtils;
|
import com.android.inputmethod.latin.utils.DictionaryInfoUtils;
|
||||||
|
@ -230,7 +230,7 @@ final public class BinaryDictionaryGetter {
|
||||||
try {
|
try {
|
||||||
// Read the version of the file
|
// Read the version of the file
|
||||||
final DictDecoder dictDecoder = FormatSpec.getDictDecoder(f);
|
final DictDecoder dictDecoder = FormatSpec.getDictDecoder(f);
|
||||||
final FileHeader header = dictDecoder.readHeader();
|
final DictionaryHeader header = dictDecoder.readHeader();
|
||||||
|
|
||||||
final String version = header.mDictionaryOptions.mAttributes.get(VERSION_KEY);
|
final String version = header.mDictionaryOptions.mAttributes.get(VERSION_KEY);
|
||||||
if (null == version) {
|
if (null == version) {
|
||||||
|
|
|
@ -21,6 +21,7 @@ import android.util.Log;
|
||||||
|
|
||||||
import com.android.inputmethod.annotations.UsedForTesting;
|
import com.android.inputmethod.annotations.UsedForTesting;
|
||||||
import com.android.inputmethod.keyboard.ProximityInfo;
|
import com.android.inputmethod.keyboard.ProximityInfo;
|
||||||
|
import com.android.inputmethod.latin.makedict.DictionaryHeader;
|
||||||
import com.android.inputmethod.latin.makedict.FormatSpec;
|
import com.android.inputmethod.latin.makedict.FormatSpec;
|
||||||
import com.android.inputmethod.latin.SuggestedWords.SuggestedWordInfo;
|
import com.android.inputmethod.latin.SuggestedWords.SuggestedWordInfo;
|
||||||
import com.android.inputmethod.latin.utils.AsyncResultHolder;
|
import com.android.inputmethod.latin.utils.AsyncResultHolder;
|
||||||
|
@ -268,9 +269,9 @@ abstract public class ExpandableBinaryDictionary extends Dictionary {
|
||||||
|
|
||||||
protected Map<String, String> getHeaderAttributeMap() {
|
protected Map<String, String> getHeaderAttributeMap() {
|
||||||
HashMap<String, String> attributeMap = new HashMap<String, String>();
|
HashMap<String, String> attributeMap = new HashMap<String, String>();
|
||||||
attributeMap.put(FormatSpec.FileHeader.DICTIONARY_ID_KEY, mDictName);
|
attributeMap.put(DictionaryHeader.DICTIONARY_ID_KEY, mDictName);
|
||||||
attributeMap.put(FormatSpec.FileHeader.DICTIONARY_LOCALE_KEY, mLocale.toString());
|
attributeMap.put(DictionaryHeader.DICTIONARY_LOCALE_KEY, mLocale.toString());
|
||||||
attributeMap.put(FormatSpec.FileHeader.DICTIONARY_VERSION_KEY,
|
attributeMap.put(DictionaryHeader.DICTIONARY_VERSION_KEY,
|
||||||
String.valueOf(TimeUnit.MILLISECONDS.toSeconds(System.currentTimeMillis())));
|
String.valueOf(TimeUnit.MILLISECONDS.toSeconds(System.currentTimeMillis())));
|
||||||
return attributeMap;
|
return attributeMap;
|
||||||
}
|
}
|
||||||
|
|
|
@ -26,7 +26,7 @@ import android.os.Environment;
|
||||||
import com.android.inputmethod.latin.BinaryDictionaryFileDumper;
|
import com.android.inputmethod.latin.BinaryDictionaryFileDumper;
|
||||||
import com.android.inputmethod.latin.BinaryDictionaryGetter;
|
import com.android.inputmethod.latin.BinaryDictionaryGetter;
|
||||||
import com.android.inputmethod.latin.R;
|
import com.android.inputmethod.latin.R;
|
||||||
import com.android.inputmethod.latin.makedict.FormatSpec.FileHeader;
|
import com.android.inputmethod.latin.makedict.DictionaryHeader;
|
||||||
import com.android.inputmethod.latin.utils.CollectionUtils;
|
import com.android.inputmethod.latin.utils.CollectionUtils;
|
||||||
import com.android.inputmethod.latin.utils.DictionaryInfoUtils;
|
import com.android.inputmethod.latin.utils.DictionaryInfoUtils;
|
||||||
import com.android.inputmethod.latin.utils.LocaleUtils;
|
import com.android.inputmethod.latin.utils.LocaleUtils;
|
||||||
|
@ -51,7 +51,7 @@ public class ExternalDictionaryGetterForDebug {
|
||||||
final File[] files = new File(SOURCE_FOLDER).listFiles();
|
final File[] files = new File(SOURCE_FOLDER).listFiles();
|
||||||
final ArrayList<String> eligibleList = CollectionUtils.newArrayList();
|
final ArrayList<String> eligibleList = CollectionUtils.newArrayList();
|
||||||
for (File f : files) {
|
for (File f : files) {
|
||||||
final FileHeader header = DictionaryInfoUtils.getDictionaryFileHeaderOrNull(f);
|
final DictionaryHeader header = DictionaryInfoUtils.getDictionaryFileHeaderOrNull(f);
|
||||||
if (null == header) continue;
|
if (null == header) continue;
|
||||||
eligibleList.add(f.getName());
|
eligibleList.add(f.getName());
|
||||||
}
|
}
|
||||||
|
@ -99,7 +99,7 @@ public class ExternalDictionaryGetterForDebug {
|
||||||
public static void askInstallFile(final Context context, final String dirPath,
|
public static void askInstallFile(final Context context, final String dirPath,
|
||||||
final String fileName, final Runnable completeRunnable) {
|
final String fileName, final Runnable completeRunnable) {
|
||||||
final File file = new File(dirPath, fileName.toString());
|
final File file = new File(dirPath, fileName.toString());
|
||||||
final FileHeader header = DictionaryInfoUtils.getDictionaryFileHeaderOrNull(file);
|
final DictionaryHeader header = DictionaryInfoUtils.getDictionaryFileHeaderOrNull(file);
|
||||||
final StringBuilder message = new StringBuilder();
|
final StringBuilder message = new StringBuilder();
|
||||||
final String locale = header.getLocaleString();
|
final String locale = header.getLocaleString();
|
||||||
for (String key : header.mDictionaryOptions.mAttributes.keySet()) {
|
for (String key : header.mDictionaryOptions.mAttributes.keySet()) {
|
||||||
|
@ -143,7 +143,7 @@ public class ExternalDictionaryGetterForDebug {
|
||||||
}
|
}
|
||||||
|
|
||||||
private static void installFile(final Context context, final File file,
|
private static void installFile(final Context context, final File file,
|
||||||
final FileHeader header) {
|
final DictionaryHeader header) {
|
||||||
BufferedOutputStream outputStream = null;
|
BufferedOutputStream outputStream = null;
|
||||||
File tempFile = null;
|
File tempFile = null;
|
||||||
try {
|
try {
|
||||||
|
|
|
@ -19,7 +19,6 @@ package com.android.inputmethod.latin.makedict;
|
||||||
import com.android.inputmethod.annotations.UsedForTesting;
|
import com.android.inputmethod.annotations.UsedForTesting;
|
||||||
import com.android.inputmethod.latin.makedict.BinaryDictDecoderUtils.CharEncoding;
|
import com.android.inputmethod.latin.makedict.BinaryDictDecoderUtils.CharEncoding;
|
||||||
import com.android.inputmethod.latin.makedict.BinaryDictDecoderUtils.DictBuffer;
|
import com.android.inputmethod.latin.makedict.BinaryDictDecoderUtils.DictBuffer;
|
||||||
import com.android.inputmethod.latin.makedict.FormatSpec.FileHeader;
|
|
||||||
import com.android.inputmethod.latin.makedict.FormatSpec.FormatOptions;
|
import com.android.inputmethod.latin.makedict.FormatSpec.FormatOptions;
|
||||||
import com.android.inputmethod.latin.makedict.FusionDictionary.WeightedString;
|
import com.android.inputmethod.latin.makedict.FusionDictionary.WeightedString;
|
||||||
|
|
||||||
|
@ -36,7 +35,7 @@ public abstract class AbstractDictDecoder implements DictDecoder {
|
||||||
private static final int ERROR_CANNOT_READ = 1;
|
private static final int ERROR_CANNOT_READ = 1;
|
||||||
private static final int ERROR_WRONG_FORMAT = 2;
|
private static final int ERROR_WRONG_FORMAT = 2;
|
||||||
|
|
||||||
protected FileHeader readHeader(final DictBuffer headerBuffer)
|
protected DictionaryHeader readHeader(final DictBuffer headerBuffer)
|
||||||
throws IOException, UnsupportedFormatException {
|
throws IOException, UnsupportedFormatException {
|
||||||
if (headerBuffer == null) {
|
if (headerBuffer == null) {
|
||||||
openDictBuffer();
|
openDictBuffer();
|
||||||
|
@ -57,10 +56,10 @@ public abstract class AbstractDictDecoder implements DictDecoder {
|
||||||
final HashMap<String, String> attributes = HeaderReader.readAttributes(headerBuffer,
|
final HashMap<String, String> attributes = HeaderReader.readAttributes(headerBuffer,
|
||||||
headerSize);
|
headerSize);
|
||||||
|
|
||||||
final FileHeader header = new FileHeader(headerSize,
|
final DictionaryHeader header = new DictionaryHeader(headerSize,
|
||||||
new FusionDictionary.DictionaryOptions(attributes),
|
new FusionDictionary.DictionaryOptions(attributes),
|
||||||
new FormatOptions(version, FileHeader.ATTRIBUTE_VALUE_TRUE.equals(
|
new FormatOptions(version, DictionaryHeader.ATTRIBUTE_VALUE_TRUE.equals(
|
||||||
attributes.get(FileHeader.HAS_HISTORICAL_INFO_KEY))));
|
attributes.get(DictionaryHeader.HAS_HISTORICAL_INFO_KEY))));
|
||||||
return header;
|
return header;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -17,7 +17,6 @@
|
||||||
package com.android.inputmethod.latin.makedict;
|
package com.android.inputmethod.latin.makedict;
|
||||||
|
|
||||||
import com.android.inputmethod.annotations.UsedForTesting;
|
import com.android.inputmethod.annotations.UsedForTesting;
|
||||||
import com.android.inputmethod.latin.makedict.FormatSpec.FileHeader;
|
|
||||||
import com.android.inputmethod.latin.makedict.FormatSpec.FormatOptions;
|
import com.android.inputmethod.latin.makedict.FormatSpec.FormatOptions;
|
||||||
import com.android.inputmethod.latin.makedict.FusionDictionary.PtNode;
|
import com.android.inputmethod.latin.makedict.FusionDictionary.PtNode;
|
||||||
import com.android.inputmethod.latin.makedict.FusionDictionary.PtNodeArray;
|
import com.android.inputmethod.latin.makedict.FusionDictionary.PtNodeArray;
|
||||||
|
@ -598,7 +597,7 @@ public final class BinaryDictDecoderUtils {
|
||||||
/* package */ static FusionDictionary readDictionaryBinary(final DictDecoder dictDecoder,
|
/* package */ static FusionDictionary readDictionaryBinary(final DictDecoder dictDecoder,
|
||||||
final FusionDictionary dict) throws IOException, UnsupportedFormatException {
|
final FusionDictionary dict) throws IOException, UnsupportedFormatException {
|
||||||
// Read header
|
// Read header
|
||||||
final FileHeader fileHeader = dictDecoder.readHeader();
|
final DictionaryHeader fileHeader = dictDecoder.readHeader();
|
||||||
|
|
||||||
Map<Integer, PtNodeArray> reverseNodeArrayMapping = new TreeMap<Integer, PtNodeArray>();
|
Map<Integer, PtNodeArray> reverseNodeArrayMapping = new TreeMap<Integer, PtNodeArray>();
|
||||||
Map<Integer, PtNode> reversePtNodeMapping = new TreeMap<Integer, PtNode>();
|
Map<Integer, PtNode> reversePtNodeMapping = new TreeMap<Integer, PtNode>();
|
||||||
|
|
|
@ -20,7 +20,6 @@ import com.android.inputmethod.annotations.UsedForTesting;
|
||||||
import com.android.inputmethod.latin.Constants;
|
import com.android.inputmethod.latin.Constants;
|
||||||
import com.android.inputmethod.latin.makedict.BinaryDictDecoderUtils.CharEncoding;
|
import com.android.inputmethod.latin.makedict.BinaryDictDecoderUtils.CharEncoding;
|
||||||
import com.android.inputmethod.latin.makedict.BinaryDictDecoderUtils.DictBuffer;
|
import com.android.inputmethod.latin.makedict.BinaryDictDecoderUtils.DictBuffer;
|
||||||
import com.android.inputmethod.latin.makedict.FormatSpec.FileHeader;
|
|
||||||
import com.android.inputmethod.latin.makedict.FormatSpec.FormatOptions;
|
import com.android.inputmethod.latin.makedict.FormatSpec.FormatOptions;
|
||||||
import com.android.inputmethod.latin.makedict.FusionDictionary.PtNode;
|
import com.android.inputmethod.latin.makedict.FusionDictionary.PtNode;
|
||||||
import com.android.inputmethod.latin.utils.ByteArrayDictBuffer;
|
import com.android.inputmethod.latin.utils.ByteArrayDictBuffer;
|
||||||
|
@ -151,7 +150,7 @@ public final class BinaryDictIOUtils {
|
||||||
final Map<Integer, ArrayList<PendingAttribute>> bigrams) throws IOException,
|
final Map<Integer, ArrayList<PendingAttribute>> bigrams) throws IOException,
|
||||||
UnsupportedFormatException {
|
UnsupportedFormatException {
|
||||||
// Read header
|
// Read header
|
||||||
final FileHeader header = dictDecoder.readHeader();
|
final DictionaryHeader header = dictDecoder.readHeader();
|
||||||
readUnigramsAndBigramsBinaryInner(dictDecoder, header.mBodyOffset, words,
|
readUnigramsAndBigramsBinaryInner(dictDecoder, header.mBodyOffset, words,
|
||||||
frequencies, bigrams, header.mFormatOptions);
|
frequencies, bigrams, header.mFormatOptions);
|
||||||
}
|
}
|
||||||
|
@ -172,7 +171,7 @@ public final class BinaryDictIOUtils {
|
||||||
if (word == null) return FormatSpec.NOT_VALID_WORD;
|
if (word == null) return FormatSpec.NOT_VALID_WORD;
|
||||||
dictDecoder.setPosition(0);
|
dictDecoder.setPosition(0);
|
||||||
|
|
||||||
final FileHeader header = dictDecoder.readHeader();
|
final DictionaryHeader header = dictDecoder.readHeader();
|
||||||
int wordPos = 0;
|
int wordPos = 0;
|
||||||
final int wordLen = word.codePointCount(0, word.length());
|
final int wordLen = word.codePointCount(0, word.length());
|
||||||
for (int depth = 0; depth < Constants.DICTIONARY_MAX_WORD_LENGTH; ++depth) {
|
for (int depth = 0; depth < Constants.DICTIONARY_MAX_WORD_LENGTH; ++depth) {
|
||||||
|
@ -311,7 +310,7 @@ public final class BinaryDictIOUtils {
|
||||||
* @param length The length of the data file.
|
* @param length The length of the data file.
|
||||||
* @return the header of the specified dictionary file.
|
* @return the header of the specified dictionary file.
|
||||||
*/
|
*/
|
||||||
private static FileHeader getDictionaryFileHeader(
|
private static DictionaryHeader getDictionaryFileHeader(
|
||||||
final File file, final long offset, final long length)
|
final File file, final long offset, final long length)
|
||||||
throws FileNotFoundException, IOException, UnsupportedFormatException {
|
throws FileNotFoundException, IOException, UnsupportedFormatException {
|
||||||
final byte[] buffer = new byte[HEADER_READING_BUFFER_SIZE];
|
final byte[] buffer = new byte[HEADER_READING_BUFFER_SIZE];
|
||||||
|
@ -337,10 +336,10 @@ public final class BinaryDictIOUtils {
|
||||||
return dictDecoder.readHeader();
|
return dictDecoder.readHeader();
|
||||||
}
|
}
|
||||||
|
|
||||||
public static FileHeader getDictionaryFileHeaderOrNull(final File file, final long offset,
|
public static DictionaryHeader getDictionaryFileHeaderOrNull(final File file, final long offset,
|
||||||
final long length) {
|
final long length) {
|
||||||
try {
|
try {
|
||||||
final FileHeader header = getDictionaryFileHeader(file, offset, length);
|
final DictionaryHeader header = getDictionaryFileHeader(file, offset, length);
|
||||||
return header;
|
return header;
|
||||||
} catch (UnsupportedFormatException e) {
|
} catch (UnsupportedFormatException e) {
|
||||||
return null;
|
return null;
|
||||||
|
|
|
@ -18,7 +18,6 @@ package com.android.inputmethod.latin.makedict;
|
||||||
|
|
||||||
import com.android.inputmethod.annotations.UsedForTesting;
|
import com.android.inputmethod.annotations.UsedForTesting;
|
||||||
import com.android.inputmethod.latin.makedict.BinaryDictDecoderUtils.DictBuffer;
|
import com.android.inputmethod.latin.makedict.BinaryDictDecoderUtils.DictBuffer;
|
||||||
import com.android.inputmethod.latin.makedict.FormatSpec.FileHeader;
|
|
||||||
import com.android.inputmethod.latin.makedict.FormatSpec.FormatOptions;
|
import com.android.inputmethod.latin.makedict.FormatSpec.FormatOptions;
|
||||||
import com.android.inputmethod.latin.utils.ByteArrayDictBuffer;
|
import com.android.inputmethod.latin.utils.ByteArrayDictBuffer;
|
||||||
|
|
||||||
|
@ -41,7 +40,7 @@ public interface DictDecoder {
|
||||||
/**
|
/**
|
||||||
* Reads and returns the file header.
|
* Reads and returns the file header.
|
||||||
*/
|
*/
|
||||||
public FileHeader readHeader() throws IOException, UnsupportedFormatException;
|
public DictionaryHeader readHeader() throws IOException, UnsupportedFormatException;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Reads PtNode from ptNodePos.
|
* Reads PtNode from ptNodePos.
|
||||||
|
|
|
@ -0,0 +1,81 @@
|
||||||
|
/*
|
||||||
|
* Copyright (C) 2014 The Android Open Source Project
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
* you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package com.android.inputmethod.latin.makedict;
|
||||||
|
|
||||||
|
import com.android.inputmethod.latin.makedict.FormatSpec.FormatOptions;
|
||||||
|
import com.android.inputmethod.latin.makedict.FusionDictionary.DictionaryOptions;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Class representing dictionary header.
|
||||||
|
*/
|
||||||
|
public final class DictionaryHeader {
|
||||||
|
public final int mBodyOffset;
|
||||||
|
public final DictionaryOptions mDictionaryOptions;
|
||||||
|
public final FormatOptions mFormatOptions;
|
||||||
|
|
||||||
|
// Note that these are corresponding definitions in native code in latinime::HeaderPolicy
|
||||||
|
// and latinime::HeaderReadWriteUtils.
|
||||||
|
// TODO: Standardize the key names and bump up the format version, taking care not to
|
||||||
|
// break format version 2 dictionaries.
|
||||||
|
public static final String DICTIONARY_VERSION_KEY = "version";
|
||||||
|
public static final String DICTIONARY_LOCALE_KEY = "locale";
|
||||||
|
public static final String DICTIONARY_ID_KEY = "dictionary";
|
||||||
|
public static final String DICTIONARY_DESCRIPTION_KEY = "description";
|
||||||
|
public static final String DICTIONARY_DATE_KEY = "date";
|
||||||
|
public static final String HAS_HISTORICAL_INFO_KEY = "HAS_HISTORICAL_INFO";
|
||||||
|
public static final String USES_FORGETTING_CURVE_KEY = "USES_FORGETTING_CURVE";
|
||||||
|
public static final String ATTRIBUTE_VALUE_TRUE = "1";
|
||||||
|
|
||||||
|
public DictionaryHeader(final int headerSize, final DictionaryOptions dictionaryOptions,
|
||||||
|
final FormatOptions formatOptions) throws UnsupportedFormatException {
|
||||||
|
mDictionaryOptions = dictionaryOptions;
|
||||||
|
mFormatOptions = formatOptions;
|
||||||
|
mBodyOffset = formatOptions.mVersion < FormatSpec.VERSION4 ? headerSize : 0;
|
||||||
|
if (null == getLocaleString()) {
|
||||||
|
throw new UnsupportedFormatException("Cannot create a FileHeader without a locale");
|
||||||
|
}
|
||||||
|
if (null == getVersion()) {
|
||||||
|
throw new UnsupportedFormatException(
|
||||||
|
"Cannot create a FileHeader without a version");
|
||||||
|
}
|
||||||
|
if (null == getId()) {
|
||||||
|
throw new UnsupportedFormatException("Cannot create a FileHeader without an ID");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Helper method to get the locale as a String
|
||||||
|
public String getLocaleString() {
|
||||||
|
return mDictionaryOptions.mAttributes.get(DICTIONARY_LOCALE_KEY);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Helper method to get the version String
|
||||||
|
public String getVersion() {
|
||||||
|
return mDictionaryOptions.mAttributes.get(DICTIONARY_VERSION_KEY);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Helper method to get the dictionary ID as a String
|
||||||
|
public String getId() {
|
||||||
|
return mDictionaryOptions.mAttributes.get(DICTIONARY_ID_KEY);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Helper method to get the description
|
||||||
|
public String getDescription() {
|
||||||
|
// TODO: Right now each dictionary file comes with a description in its own language.
|
||||||
|
// It will display as is no matter the device's locale. It should be internationalized.
|
||||||
|
return mDictionaryOptions.mAttributes.get(DICTIONARY_DESCRIPTION_KEY);
|
||||||
|
}
|
||||||
|
}
|
|
@ -19,7 +19,6 @@ package com.android.inputmethod.latin.makedict;
|
||||||
import com.android.inputmethod.annotations.UsedForTesting;
|
import com.android.inputmethod.annotations.UsedForTesting;
|
||||||
import com.android.inputmethod.latin.Constants;
|
import com.android.inputmethod.latin.Constants;
|
||||||
import com.android.inputmethod.latin.makedict.DictDecoder.DictionaryBufferFactory;
|
import com.android.inputmethod.latin.makedict.DictDecoder.DictionaryBufferFactory;
|
||||||
import com.android.inputmethod.latin.makedict.FusionDictionary.DictionaryOptions;
|
|
||||||
|
|
||||||
import java.io.File;
|
import java.io.File;
|
||||||
|
|
||||||
|
@ -329,66 +328,6 @@ public final class FormatSpec {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* Class representing file header.
|
|
||||||
*/
|
|
||||||
public static final class FileHeader {
|
|
||||||
public final int mBodyOffset;
|
|
||||||
public final DictionaryOptions mDictionaryOptions;
|
|
||||||
public final FormatOptions mFormatOptions;
|
|
||||||
|
|
||||||
// Note that these are corresponding definitions in native code in latinime::HeaderPolicy
|
|
||||||
// and latinime::HeaderReadWriteUtils.
|
|
||||||
// TODO: Standardize the key names and bump up the format version, taking care not to
|
|
||||||
// break format version 2 dictionaries.
|
|
||||||
public static final String DICTIONARY_VERSION_KEY = "version";
|
|
||||||
public static final String DICTIONARY_LOCALE_KEY = "locale";
|
|
||||||
public static final String DICTIONARY_ID_KEY = "dictionary";
|
|
||||||
public static final String DICTIONARY_DESCRIPTION_KEY = "description";
|
|
||||||
public static final String DICTIONARY_DATE_KEY = "date";
|
|
||||||
public static final String HAS_HISTORICAL_INFO_KEY = "HAS_HISTORICAL_INFO";
|
|
||||||
public static final String USES_FORGETTING_CURVE_KEY = "USES_FORGETTING_CURVE";
|
|
||||||
public static final String ATTRIBUTE_VALUE_TRUE = "1";
|
|
||||||
public FileHeader(final int headerSize, final DictionaryOptions dictionaryOptions,
|
|
||||||
final FormatOptions formatOptions) throws UnsupportedFormatException {
|
|
||||||
mDictionaryOptions = dictionaryOptions;
|
|
||||||
mFormatOptions = formatOptions;
|
|
||||||
mBodyOffset = formatOptions.mVersion < VERSION4 ? headerSize : 0;
|
|
||||||
if (null == getLocaleString()) {
|
|
||||||
throw new UnsupportedFormatException("Cannot create a FileHeader without a locale");
|
|
||||||
}
|
|
||||||
if (null == getVersion()) {
|
|
||||||
throw new UnsupportedFormatException(
|
|
||||||
"Cannot create a FileHeader without a version");
|
|
||||||
}
|
|
||||||
if (null == getId()) {
|
|
||||||
throw new UnsupportedFormatException("Cannot create a FileHeader without an ID");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Helper method to get the locale as a String
|
|
||||||
public String getLocaleString() {
|
|
||||||
return mDictionaryOptions.mAttributes.get(FileHeader.DICTIONARY_LOCALE_KEY);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Helper method to get the version String
|
|
||||||
public String getVersion() {
|
|
||||||
return mDictionaryOptions.mAttributes.get(FileHeader.DICTIONARY_VERSION_KEY);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Helper method to get the dictionary ID as a String
|
|
||||||
public String getId() {
|
|
||||||
return mDictionaryOptions.mAttributes.get(FileHeader.DICTIONARY_ID_KEY);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Helper method to get the description
|
|
||||||
public String getDescription() {
|
|
||||||
// TODO: Right now each dictionary file comes with a description in its own language.
|
|
||||||
// It will display as is no matter the device's locale. It should be internationalized.
|
|
||||||
return mDictionaryOptions.mAttributes.get(FileHeader.DICTIONARY_DESCRIPTION_KEY);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Returns new dictionary decoder.
|
* Returns new dictionary decoder.
|
||||||
*
|
*
|
||||||
|
|
|
@ -19,7 +19,6 @@ package com.android.inputmethod.latin.makedict;
|
||||||
import com.android.inputmethod.annotations.UsedForTesting;
|
import com.android.inputmethod.annotations.UsedForTesting;
|
||||||
import com.android.inputmethod.latin.makedict.BinaryDictDecoderUtils.CharEncoding;
|
import com.android.inputmethod.latin.makedict.BinaryDictDecoderUtils.CharEncoding;
|
||||||
import com.android.inputmethod.latin.makedict.BinaryDictDecoderUtils.DictBuffer;
|
import com.android.inputmethod.latin.makedict.BinaryDictDecoderUtils.DictBuffer;
|
||||||
import com.android.inputmethod.latin.makedict.FormatSpec.FileHeader;
|
|
||||||
import com.android.inputmethod.latin.makedict.FormatSpec.FormatOptions;
|
import com.android.inputmethod.latin.makedict.FormatSpec.FormatOptions;
|
||||||
import com.android.inputmethod.latin.makedict.FusionDictionary.PtNode;
|
import com.android.inputmethod.latin.makedict.FusionDictionary.PtNode;
|
||||||
import com.android.inputmethod.latin.makedict.FusionDictionary.WeightedString;
|
import com.android.inputmethod.latin.makedict.FusionDictionary.WeightedString;
|
||||||
|
@ -90,11 +89,11 @@ public class Ver2DictDecoder extends AbstractDictDecoder {
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public FileHeader readHeader() throws IOException, UnsupportedFormatException {
|
public DictionaryHeader readHeader() throws IOException, UnsupportedFormatException {
|
||||||
if (mDictBuffer == null) {
|
if (mDictBuffer == null) {
|
||||||
openDictBuffer();
|
openDictBuffer();
|
||||||
}
|
}
|
||||||
final FileHeader header = super.readHeader(mDictBuffer);
|
final DictionaryHeader header = super.readHeader(mDictBuffer);
|
||||||
final int version = header.mFormatOptions.mVersion;
|
final int version = header.mFormatOptions.mVersion;
|
||||||
if (!(version >= 2 && version <= 3)) {
|
if (!(version >= 2 && version <= 3)) {
|
||||||
throw new UnsupportedFormatException("File header has a wrong version : " + version);
|
throw new UnsupportedFormatException("File header has a wrong version : " + version);
|
||||||
|
|
|
@ -19,7 +19,6 @@ package com.android.inputmethod.latin.makedict;
|
||||||
import com.android.inputmethod.annotations.UsedForTesting;
|
import com.android.inputmethod.annotations.UsedForTesting;
|
||||||
import com.android.inputmethod.latin.makedict.BinaryDictDecoderUtils.CharEncoding;
|
import com.android.inputmethod.latin.makedict.BinaryDictDecoderUtils.CharEncoding;
|
||||||
import com.android.inputmethod.latin.makedict.BinaryDictDecoderUtils.DictBuffer;
|
import com.android.inputmethod.latin.makedict.BinaryDictDecoderUtils.DictBuffer;
|
||||||
import com.android.inputmethod.latin.makedict.FormatSpec.FileHeader;
|
|
||||||
import com.android.inputmethod.latin.makedict.FormatSpec.FormatOptions;
|
import com.android.inputmethod.latin.makedict.FormatSpec.FormatOptions;
|
||||||
import com.android.inputmethod.latin.makedict.FusionDictionary.PtNode;
|
import com.android.inputmethod.latin.makedict.FusionDictionary.PtNode;
|
||||||
import com.android.inputmethod.latin.makedict.FusionDictionary.WeightedString;
|
import com.android.inputmethod.latin.makedict.FusionDictionary.WeightedString;
|
||||||
|
@ -166,12 +165,12 @@ public class Ver4DictDecoder extends AbstractDictDecoder {
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public FileHeader readHeader() throws IOException, UnsupportedFormatException {
|
public DictionaryHeader readHeader() throws IOException, UnsupportedFormatException {
|
||||||
if (mHeaderBuffer == null) {
|
if (mHeaderBuffer == null) {
|
||||||
openDictBuffer();
|
openDictBuffer();
|
||||||
}
|
}
|
||||||
mHeaderBuffer.position(0);
|
mHeaderBuffer.position(0);
|
||||||
final FileHeader header = super.readHeader(mHeaderBuffer);
|
final DictionaryHeader header = super.readHeader(mHeaderBuffer);
|
||||||
final int version = header.mFormatOptions.mVersion;
|
final int version = header.mFormatOptions.mVersion;
|
||||||
if (version != FormatSpec.VERSION4) {
|
if (version != FormatSpec.VERSION4) {
|
||||||
throw new UnsupportedFormatException("File header has a wrong version : " + version);
|
throw new UnsupportedFormatException("File header has a wrong version : " + version);
|
||||||
|
|
|
@ -62,7 +62,7 @@ public class Ver4DictEncoder implements DictEncoder {
|
||||||
final BinaryDictionary binaryDict = new BinaryDictionary(mDictPlacedDir.getAbsolutePath(),
|
final BinaryDictionary binaryDict = new BinaryDictionary(mDictPlacedDir.getAbsolutePath(),
|
||||||
0l, mDictPlacedDir.length(), true /* useFullEditDistance */,
|
0l, mDictPlacedDir.length(), true /* useFullEditDistance */,
|
||||||
LocaleUtils.constructLocaleFromString(dict.mOptions.mAttributes.get(
|
LocaleUtils.constructLocaleFromString(dict.mOptions.mAttributes.get(
|
||||||
FormatSpec.FileHeader.DICTIONARY_LOCALE_KEY)),
|
DictionaryHeader.DICTIONARY_LOCALE_KEY)),
|
||||||
Dictionary.TYPE_USER /* Dictionary type. Does not matter for us */,
|
Dictionary.TYPE_USER /* Dictionary type. Does not matter for us */,
|
||||||
true /* isUpdatable */);
|
true /* isUpdatable */);
|
||||||
if (!binaryDict.isValidDictionary()) {
|
if (!binaryDict.isValidDictionary()) {
|
||||||
|
|
|
@ -22,7 +22,7 @@ import com.android.inputmethod.annotations.UsedForTesting;
|
||||||
import com.android.inputmethod.latin.Constants;
|
import com.android.inputmethod.latin.Constants;
|
||||||
import com.android.inputmethod.latin.Dictionary;
|
import com.android.inputmethod.latin.Dictionary;
|
||||||
import com.android.inputmethod.latin.ExpandableBinaryDictionary;
|
import com.android.inputmethod.latin.ExpandableBinaryDictionary;
|
||||||
import com.android.inputmethod.latin.makedict.FormatSpec;
|
import com.android.inputmethod.latin.makedict.DictionaryHeader;
|
||||||
import com.android.inputmethod.latin.utils.LanguageModelParam;
|
import com.android.inputmethod.latin.utils.LanguageModelParam;
|
||||||
|
|
||||||
import java.io.File;
|
import java.io.File;
|
||||||
|
@ -86,13 +86,13 @@ public abstract class DecayingExpandableBinaryDictionaryBase extends ExpandableB
|
||||||
@Override
|
@Override
|
||||||
protected Map<String, String> getHeaderAttributeMap() {
|
protected Map<String, String> getHeaderAttributeMap() {
|
||||||
HashMap<String, String> attributeMap = new HashMap<String, String>();
|
HashMap<String, String> attributeMap = new HashMap<String, String>();
|
||||||
attributeMap.put(FormatSpec.FileHeader.USES_FORGETTING_CURVE_KEY,
|
attributeMap.put(DictionaryHeader.USES_FORGETTING_CURVE_KEY,
|
||||||
FormatSpec.FileHeader.ATTRIBUTE_VALUE_TRUE);
|
DictionaryHeader.ATTRIBUTE_VALUE_TRUE);
|
||||||
attributeMap.put(FormatSpec.FileHeader.HAS_HISTORICAL_INFO_KEY,
|
attributeMap.put(DictionaryHeader.HAS_HISTORICAL_INFO_KEY,
|
||||||
FormatSpec.FileHeader.ATTRIBUTE_VALUE_TRUE);
|
DictionaryHeader.ATTRIBUTE_VALUE_TRUE);
|
||||||
attributeMap.put(FormatSpec.FileHeader.DICTIONARY_ID_KEY, mDictName);
|
attributeMap.put(DictionaryHeader.DICTIONARY_ID_KEY, mDictName);
|
||||||
attributeMap.put(FormatSpec.FileHeader.DICTIONARY_LOCALE_KEY, mLocale.toString());
|
attributeMap.put(DictionaryHeader.DICTIONARY_LOCALE_KEY, mLocale.toString());
|
||||||
attributeMap.put(FormatSpec.FileHeader.DICTIONARY_VERSION_KEY,
|
attributeMap.put(DictionaryHeader.DICTIONARY_VERSION_KEY,
|
||||||
String.valueOf(TimeUnit.MILLISECONDS.toSeconds(System.currentTimeMillis())));
|
String.valueOf(TimeUnit.MILLISECONDS.toSeconds(System.currentTimeMillis())));
|
||||||
return attributeMap;
|
return attributeMap;
|
||||||
}
|
}
|
||||||
|
|
|
@ -29,7 +29,7 @@ import com.android.inputmethod.latin.BinaryDictionaryGetter;
|
||||||
import com.android.inputmethod.latin.Constants;
|
import com.android.inputmethod.latin.Constants;
|
||||||
import com.android.inputmethod.latin.R;
|
import com.android.inputmethod.latin.R;
|
||||||
import com.android.inputmethod.latin.makedict.BinaryDictIOUtils;
|
import com.android.inputmethod.latin.makedict.BinaryDictIOUtils;
|
||||||
import com.android.inputmethod.latin.makedict.FormatSpec.FileHeader;
|
import com.android.inputmethod.latin.makedict.DictionaryHeader;
|
||||||
import com.android.inputmethod.latin.settings.SpacingAndPunctuations;
|
import com.android.inputmethod.latin.settings.SpacingAndPunctuations;
|
||||||
|
|
||||||
import java.io.File;
|
import java.io.File;
|
||||||
|
@ -282,7 +282,7 @@ public class DictionaryInfoUtils {
|
||||||
BinaryDictionaryGetter.ID_CATEGORY_SEPARATOR + locale.getLanguage().toString();
|
BinaryDictionaryGetter.ID_CATEGORY_SEPARATOR + locale.getLanguage().toString();
|
||||||
}
|
}
|
||||||
|
|
||||||
public static FileHeader getDictionaryFileHeaderOrNull(final File file) {
|
public static DictionaryHeader getDictionaryFileHeaderOrNull(final File file) {
|
||||||
return BinaryDictIOUtils.getDictionaryFileHeaderOrNull(file, 0, file.length());
|
return BinaryDictIOUtils.getDictionaryFileHeaderOrNull(file, 0, file.length());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -294,7 +294,7 @@ public class DictionaryInfoUtils {
|
||||||
*/
|
*/
|
||||||
private static DictionaryInfo createDictionaryInfoFromFileAddress(
|
private static DictionaryInfo createDictionaryInfoFromFileAddress(
|
||||||
final AssetFileAddress fileAddress) {
|
final AssetFileAddress fileAddress) {
|
||||||
final FileHeader header = BinaryDictIOUtils.getDictionaryFileHeaderOrNull(
|
final DictionaryHeader header = BinaryDictIOUtils.getDictionaryFileHeaderOrNull(
|
||||||
new File(fileAddress.mFilename), fileAddress.mOffset, fileAddress.mLength);
|
new File(fileAddress.mFilename), fileAddress.mOffset, fileAddress.mLength);
|
||||||
if (header == null) {
|
if (header == null) {
|
||||||
return null;
|
return null;
|
||||||
|
|
|
@ -22,6 +22,7 @@ import android.util.Pair;
|
||||||
|
|
||||||
import com.android.inputmethod.latin.makedict.CodePointUtils;
|
import com.android.inputmethod.latin.makedict.CodePointUtils;
|
||||||
import com.android.inputmethod.latin.makedict.DictDecoder;
|
import com.android.inputmethod.latin.makedict.DictDecoder;
|
||||||
|
import com.android.inputmethod.latin.makedict.DictionaryHeader;
|
||||||
import com.android.inputmethod.latin.makedict.FormatSpec;
|
import com.android.inputmethod.latin.makedict.FormatSpec;
|
||||||
import com.android.inputmethod.latin.makedict.FusionDictionary;
|
import com.android.inputmethod.latin.makedict.FusionDictionary;
|
||||||
import com.android.inputmethod.latin.makedict.FusionDictionary.PtNode;
|
import com.android.inputmethod.latin.makedict.FusionDictionary.PtNode;
|
||||||
|
@ -102,14 +103,14 @@ public class BinaryDictionaryDecayingTests extends AndroidTestCase {
|
||||||
getContext().getCacheDir());
|
getContext().getCacheDir());
|
||||||
FileUtils.deleteRecursively(file);
|
FileUtils.deleteRecursively(file);
|
||||||
Map<String, String> attributeMap = new HashMap<String, String>();
|
Map<String, String> attributeMap = new HashMap<String, String>();
|
||||||
attributeMap.put(FormatSpec.FileHeader.DICTIONARY_ID_KEY, dictId);
|
attributeMap.put(DictionaryHeader.DICTIONARY_ID_KEY, dictId);
|
||||||
attributeMap.put(FormatSpec.FileHeader.DICTIONARY_LOCALE_KEY, dictId);
|
attributeMap.put(DictionaryHeader.DICTIONARY_LOCALE_KEY, dictId);
|
||||||
attributeMap.put(FormatSpec.FileHeader.DICTIONARY_VERSION_KEY,
|
attributeMap.put(DictionaryHeader.DICTIONARY_VERSION_KEY,
|
||||||
String.valueOf(TimeUnit.MILLISECONDS.toSeconds(System.currentTimeMillis())));
|
String.valueOf(TimeUnit.MILLISECONDS.toSeconds(System.currentTimeMillis())));
|
||||||
attributeMap.put(FormatSpec.FileHeader.USES_FORGETTING_CURVE_KEY,
|
attributeMap.put(DictionaryHeader.USES_FORGETTING_CURVE_KEY,
|
||||||
FormatSpec.FileHeader.ATTRIBUTE_VALUE_TRUE);
|
DictionaryHeader.ATTRIBUTE_VALUE_TRUE);
|
||||||
attributeMap.put(FormatSpec.FileHeader.HAS_HISTORICAL_INFO_KEY,
|
attributeMap.put(DictionaryHeader.HAS_HISTORICAL_INFO_KEY,
|
||||||
FormatSpec.FileHeader.ATTRIBUTE_VALUE_TRUE);
|
DictionaryHeader.ATTRIBUTE_VALUE_TRUE);
|
||||||
if (BinaryDictionary.createEmptyDictFile(file.getAbsolutePath(),
|
if (BinaryDictionary.createEmptyDictFile(file.getAbsolutePath(),
|
||||||
FormatSpec.VERSION4, attributeMap)) {
|
FormatSpec.VERSION4, attributeMap)) {
|
||||||
return file;
|
return file;
|
||||||
|
|
|
@ -24,7 +24,6 @@ import android.util.SparseArray;
|
||||||
import com.android.inputmethod.latin.BinaryDictionary;
|
import com.android.inputmethod.latin.BinaryDictionary;
|
||||||
import com.android.inputmethod.latin.makedict.BinaryDictDecoderUtils.CharEncoding;
|
import com.android.inputmethod.latin.makedict.BinaryDictDecoderUtils.CharEncoding;
|
||||||
import com.android.inputmethod.latin.makedict.BinaryDictDecoderUtils.DictBuffer;
|
import com.android.inputmethod.latin.makedict.BinaryDictDecoderUtils.DictBuffer;
|
||||||
import com.android.inputmethod.latin.makedict.FormatSpec.FileHeader;
|
|
||||||
import com.android.inputmethod.latin.makedict.FormatSpec.FormatOptions;
|
import com.android.inputmethod.latin.makedict.FormatSpec.FormatOptions;
|
||||||
import com.android.inputmethod.latin.makedict.FusionDictionary.PtNode;
|
import com.android.inputmethod.latin.makedict.FusionDictionary.PtNode;
|
||||||
import com.android.inputmethod.latin.makedict.FusionDictionary.PtNodeArray;
|
import com.android.inputmethod.latin.makedict.FusionDictionary.PtNodeArray;
|
||||||
|
@ -498,7 +497,7 @@ public class BinaryDictDecoderEncoderTests extends AndroidTestCase {
|
||||||
private String getWordFromBinary(final DictDecoder dictDecoder, final int address) {
|
private String getWordFromBinary(final DictDecoder dictDecoder, final int address) {
|
||||||
if (dictDecoder.getPosition() != 0) dictDecoder.setPosition(0);
|
if (dictDecoder.getPosition() != 0) dictDecoder.setPosition(0);
|
||||||
|
|
||||||
FileHeader fileHeader = null;
|
DictionaryHeader fileHeader = null;
|
||||||
try {
|
try {
|
||||||
fileHeader = dictDecoder.readHeader();
|
fileHeader = dictDecoder.readHeader();
|
||||||
} catch (IOException e) {
|
} catch (IOException e) {
|
||||||
|
|
|
@ -16,7 +16,6 @@
|
||||||
|
|
||||||
package com.android.inputmethod.latin.makedict;
|
package com.android.inputmethod.latin.makedict;
|
||||||
|
|
||||||
import com.android.inputmethod.latin.makedict.FormatSpec.FileHeader;
|
|
||||||
import com.android.inputmethod.latin.makedict.FormatSpec.FormatOptions;
|
import com.android.inputmethod.latin.makedict.FormatSpec.FormatOptions;
|
||||||
import com.android.inputmethod.latin.makedict.FusionDictionary.DictionaryOptions;
|
import com.android.inputmethod.latin.makedict.FusionDictionary.DictionaryOptions;
|
||||||
|
|
||||||
|
@ -39,14 +38,14 @@ public class BinaryDictUtils {
|
||||||
public static DictionaryOptions makeDictionaryOptions(final String id, final String version,
|
public static DictionaryOptions makeDictionaryOptions(final String id, final String version,
|
||||||
final FormatSpec.FormatOptions formatOptions) {
|
final FormatSpec.FormatOptions formatOptions) {
|
||||||
final DictionaryOptions options = new DictionaryOptions(new HashMap<String, String>());
|
final DictionaryOptions options = new DictionaryOptions(new HashMap<String, String>());
|
||||||
options.mAttributes.put(FileHeader.DICTIONARY_LOCALE_KEY, "en_US");
|
options.mAttributes.put(DictionaryHeader.DICTIONARY_LOCALE_KEY, "en_US");
|
||||||
options.mAttributes.put(FileHeader.DICTIONARY_ID_KEY, id);
|
options.mAttributes.put(DictionaryHeader.DICTIONARY_ID_KEY, id);
|
||||||
options.mAttributes.put(FileHeader.DICTIONARY_VERSION_KEY, version);
|
options.mAttributes.put(DictionaryHeader.DICTIONARY_VERSION_KEY, version);
|
||||||
if (formatOptions.mHasTimestamp) {
|
if (formatOptions.mHasTimestamp) {
|
||||||
options.mAttributes.put(FileHeader.HAS_HISTORICAL_INFO_KEY,
|
options.mAttributes.put(DictionaryHeader.HAS_HISTORICAL_INFO_KEY,
|
||||||
FileHeader.ATTRIBUTE_VALUE_TRUE);
|
DictionaryHeader.ATTRIBUTE_VALUE_TRUE);
|
||||||
options.mAttributes.put(FileHeader.USES_FORGETTING_CURVE_KEY,
|
options.mAttributes.put(DictionaryHeader.USES_FORGETTING_CURVE_KEY,
|
||||||
FileHeader.ATTRIBUTE_VALUE_TRUE);
|
DictionaryHeader.ATTRIBUTE_VALUE_TRUE);
|
||||||
}
|
}
|
||||||
return options;
|
return options;
|
||||||
}
|
}
|
||||||
|
|
|
@ -18,6 +18,7 @@ package com.android.inputmethod.latin.dicttool;
|
||||||
|
|
||||||
import com.android.inputmethod.latin.makedict.DictDecoder;
|
import com.android.inputmethod.latin.makedict.DictDecoder;
|
||||||
import com.android.inputmethod.latin.makedict.DictEncoder;
|
import com.android.inputmethod.latin.makedict.DictEncoder;
|
||||||
|
import com.android.inputmethod.latin.makedict.DictionaryHeader;
|
||||||
import com.android.inputmethod.latin.makedict.FormatSpec;
|
import com.android.inputmethod.latin.makedict.FormatSpec;
|
||||||
import com.android.inputmethod.latin.makedict.FormatSpec.FormatOptions;
|
import com.android.inputmethod.latin.makedict.FormatSpec.FormatOptions;
|
||||||
import com.android.inputmethod.latin.makedict.FusionDictionary;
|
import com.android.inputmethod.latin.makedict.FusionDictionary;
|
||||||
|
@ -48,9 +49,9 @@ public class BinaryDictOffdeviceUtilsTests extends TestCase {
|
||||||
|
|
||||||
// Create a thrice-compressed dictionary file.
|
// Create a thrice-compressed dictionary file.
|
||||||
final DictionaryOptions testOptions = new DictionaryOptions(new HashMap<String, String>());
|
final DictionaryOptions testOptions = new DictionaryOptions(new HashMap<String, String>());
|
||||||
testOptions.mAttributes.put(FormatSpec.FileHeader.DICTIONARY_VERSION_KEY, VERSION);
|
testOptions.mAttributes.put(DictionaryHeader.DICTIONARY_VERSION_KEY, VERSION);
|
||||||
testOptions.mAttributes.put(FormatSpec.FileHeader.DICTIONARY_LOCALE_KEY, LOCALE);
|
testOptions.mAttributes.put(DictionaryHeader.DICTIONARY_LOCALE_KEY, LOCALE);
|
||||||
testOptions.mAttributes.put(FormatSpec.FileHeader.DICTIONARY_ID_KEY, ID);
|
testOptions.mAttributes.put(DictionaryHeader.DICTIONARY_ID_KEY, ID);
|
||||||
final FusionDictionary dict = new FusionDictionary(new PtNodeArray(), testOptions);
|
final FusionDictionary dict = new FusionDictionary(new PtNodeArray(), testOptions);
|
||||||
dict.add("foo", TEST_FREQ, null, false /* isNotAWord */);
|
dict.add("foo", TEST_FREQ, null, false /* isNotAWord */);
|
||||||
dict.add("fta", 1, null, false /* isNotAWord */);
|
dict.add("fta", 1, null, false /* isNotAWord */);
|
||||||
|
@ -80,11 +81,11 @@ public class BinaryDictOffdeviceUtilsTests extends TestCase {
|
||||||
null /* dict : an optional dictionary to add words to, or null */,
|
null /* dict : an optional dictionary to add words to, or null */,
|
||||||
false /* deleteDictIfBroken */);
|
false /* deleteDictIfBroken */);
|
||||||
assertEquals("Wrong version attribute", VERSION, resultDict.mOptions.mAttributes.get(
|
assertEquals("Wrong version attribute", VERSION, resultDict.mOptions.mAttributes.get(
|
||||||
FormatSpec.FileHeader.DICTIONARY_VERSION_KEY));
|
DictionaryHeader.DICTIONARY_VERSION_KEY));
|
||||||
assertEquals("Wrong locale attribute", LOCALE, resultDict.mOptions.mAttributes.get(
|
assertEquals("Wrong locale attribute", LOCALE, resultDict.mOptions.mAttributes.get(
|
||||||
FormatSpec.FileHeader.DICTIONARY_LOCALE_KEY));
|
DictionaryHeader.DICTIONARY_LOCALE_KEY));
|
||||||
assertEquals("Wrong id attribute", ID, resultDict.mOptions.mAttributes.get(
|
assertEquals("Wrong id attribute", ID, resultDict.mOptions.mAttributes.get(
|
||||||
FormatSpec.FileHeader.DICTIONARY_ID_KEY));
|
DictionaryHeader.DICTIONARY_ID_KEY));
|
||||||
assertEquals("Dictionary can't be read back correctly",
|
assertEquals("Dictionary can't be read back correctly",
|
||||||
FusionDictionary.findWordInTree(resultDict.mRootNodeArray, "foo").getFrequency(),
|
FusionDictionary.findWordInTree(resultDict.mRootNodeArray, "foo").getFrequency(),
|
||||||
TEST_FREQ);
|
TEST_FREQ);
|
||||||
|
|
Loading…
Reference in a new issue