diff options
author | 2014-01-06 01:55:00 -0800 | |
---|---|---|
committer | 2014-01-06 01:55:00 -0800 | |
commit | 0991d8e92200035335f62907b0aa3937e1253651 (patch) | |
tree | 3552103a95246e2f62f5c239b93ea20b2fafb3dd /java/src/com/android/inputmethod/latin/utils/DictionaryInfoUtils.java | |
parent | 77c9b8dd2f01c8d5c65684be7c0ac4e02a6023ff (diff) | |
parent | 6d5f9fd3d1ee903f9355905326cd75e7ee603d4e (diff) | |
download | latinime-0991d8e92200035335f62907b0aa3937e1253651.tar.gz latinime-0991d8e92200035335f62907b0aa3937e1253651.tar.xz latinime-0991d8e92200035335f62907b0aa3937e1253651.zip |
am 6d5f9fd3: Merge "Fix possible NPE."
* commit '6d5f9fd3d1ee903f9355905326cd75e7ee603d4e':
Fix possible NPE.
Diffstat (limited to 'java/src/com/android/inputmethod/latin/utils/DictionaryInfoUtils.java')
-rw-r--r-- | java/src/com/android/inputmethod/latin/utils/DictionaryInfoUtils.java | 11 |
1 files changed, 10 insertions, 1 deletions
diff --git a/java/src/com/android/inputmethod/latin/utils/DictionaryInfoUtils.java b/java/src/com/android/inputmethod/latin/utils/DictionaryInfoUtils.java index 021bf0825..3daa63ff4 100644 --- a/java/src/com/android/inputmethod/latin/utils/DictionaryInfoUtils.java +++ b/java/src/com/android/inputmethod/latin/utils/DictionaryInfoUtils.java @@ -282,10 +282,19 @@ public class DictionaryInfoUtils { return BinaryDictIOUtils.getDictionaryFileHeaderOrNull(file, 0, file.length()); } + /** + * Returns information of the dictionary. + * + * @param fileAddress the asset dictionary file address. + * @return information of the specified dictionary. + */ private static DictionaryInfo createDictionaryInfoFromFileAddress( final AssetFileAddress fileAddress) { final FileHeader header = BinaryDictIOUtils.getDictionaryFileHeaderOrNull( new File(fileAddress.mFilename), fileAddress.mOffset, fileAddress.mLength); + if (header == null) { + return null; + } final String id = header.getId(); final Locale locale = LocaleUtils.constructLocaleFromString(header.getLocaleString()); final String description = header.getDescription(); @@ -328,7 +337,7 @@ public class DictionaryInfoUtils { // Protect against cases of a less-specific dictionary being found, like an // en dictionary being used for an en_US locale. In this case, the en dictionary // should be used for en_US but discounted for listing purposes. - if (!dictionaryInfo.mLocale.equals(locale)) continue; + if (dictionaryInfo == null || !dictionaryInfo.mLocale.equals(locale)) continue; addOrUpdateDictInfo(dictList, dictionaryInfo); } } |