Remove dependency from StringUtils to Json
Change-Id: I2a89497fb9ec12a37ba09f4598742e88f6700576
This commit is contained in:
parent
79cc690f55
commit
9fa221a7bd
4 changed files with 110 additions and 81 deletions
|
@ -25,7 +25,7 @@ import com.android.inputmethod.keyboard.Key;
|
||||||
import com.android.inputmethod.keyboard.Keyboard;
|
import com.android.inputmethod.keyboard.Keyboard;
|
||||||
import com.android.inputmethod.latin.settings.Settings;
|
import com.android.inputmethod.latin.settings.Settings;
|
||||||
import com.android.inputmethod.latin.utils.CollectionUtils;
|
import com.android.inputmethod.latin.utils.CollectionUtils;
|
||||||
import com.android.inputmethod.latin.utils.StringUtils;
|
import com.android.inputmethod.latin.utils.JsonUtils;
|
||||||
|
|
||||||
import java.util.ArrayDeque;
|
import java.util.ArrayDeque;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
|
@ -139,7 +139,7 @@ public class DynamicGridKeyboard extends Keyboard {
|
||||||
keys.add(key.getCode());
|
keys.add(key.getCode());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
final String jsonStr = StringUtils.listToJsonStr(keys);
|
final String jsonStr = JsonUtils.listToJsonStr(keys);
|
||||||
Settings.writeEmojiRecentKeys(mPrefs, jsonStr);
|
Settings.writeEmojiRecentKeys(mPrefs, jsonStr);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -167,7 +167,7 @@ public class DynamicGridKeyboard extends Keyboard {
|
||||||
|
|
||||||
public void loadRecentKeys(final Collection<DynamicGridKeyboard> keyboards) {
|
public void loadRecentKeys(final Collection<DynamicGridKeyboard> keyboards) {
|
||||||
final String str = Settings.readEmojiRecentKeys(mPrefs);
|
final String str = Settings.readEmojiRecentKeys(mPrefs);
|
||||||
final List<Object> keys = StringUtils.jsonStrToList(str);
|
final List<Object> keys = JsonUtils.jsonStrToList(str);
|
||||||
for (final Object o : keys) {
|
for (final Object o : keys) {
|
||||||
final Key key;
|
final Key key;
|
||||||
if (o instanceof Integer) {
|
if (o instanceof Integer) {
|
||||||
|
|
103
java/src/com/android/inputmethod/latin/utils/JsonUtils.java
Normal file
103
java/src/com/android/inputmethod/latin/utils/JsonUtils.java
Normal file
|
@ -0,0 +1,103 @@
|
||||||
|
/*
|
||||||
|
* Copyright (C) 2013 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.utils;
|
||||||
|
|
||||||
|
import android.util.JsonReader;
|
||||||
|
import android.util.JsonWriter;
|
||||||
|
import android.util.Log;
|
||||||
|
|
||||||
|
import java.io.Closeable;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.io.StringReader;
|
||||||
|
import java.io.StringWriter;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.Collections;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
public final class JsonUtils {
|
||||||
|
private static final String TAG = JsonUtils.class.getSimpleName();
|
||||||
|
|
||||||
|
private static final String INTEGER_CLASS_NAME = Integer.class.getSimpleName();
|
||||||
|
private static final String STRING_CLASS_NAME = String.class.getSimpleName();
|
||||||
|
|
||||||
|
private static final String EMPTY_STRING = "";
|
||||||
|
|
||||||
|
public static List<Object> jsonStrToList(final String s) {
|
||||||
|
final ArrayList<Object> list = CollectionUtils.newArrayList();
|
||||||
|
final JsonReader reader = new JsonReader(new StringReader(s));
|
||||||
|
try {
|
||||||
|
reader.beginArray();
|
||||||
|
while (reader.hasNext()) {
|
||||||
|
reader.beginObject();
|
||||||
|
while (reader.hasNext()) {
|
||||||
|
final String name = reader.nextName();
|
||||||
|
if (name.equals(INTEGER_CLASS_NAME)) {
|
||||||
|
list.add(reader.nextInt());
|
||||||
|
} else if (name.equals(STRING_CLASS_NAME)) {
|
||||||
|
list.add(reader.nextString());
|
||||||
|
} else {
|
||||||
|
Log.w(TAG, "Invalid name: " + name);
|
||||||
|
reader.skipValue();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
reader.endObject();
|
||||||
|
}
|
||||||
|
reader.endArray();
|
||||||
|
return list;
|
||||||
|
} catch (final IOException e) {
|
||||||
|
} finally {
|
||||||
|
close(reader);
|
||||||
|
}
|
||||||
|
return Collections.<Object>emptyList();
|
||||||
|
}
|
||||||
|
|
||||||
|
public static String listToJsonStr(final List<Object> list) {
|
||||||
|
if (list == null || list.isEmpty()) {
|
||||||
|
return EMPTY_STRING;
|
||||||
|
}
|
||||||
|
final StringWriter sw = new StringWriter();
|
||||||
|
final JsonWriter writer = new JsonWriter(sw);
|
||||||
|
try {
|
||||||
|
writer.beginArray();
|
||||||
|
for (final Object o : list) {
|
||||||
|
writer.beginObject();
|
||||||
|
if (o instanceof Integer) {
|
||||||
|
writer.name(INTEGER_CLASS_NAME).value((Integer)o);
|
||||||
|
} else if (o instanceof String) {
|
||||||
|
writer.name(STRING_CLASS_NAME).value((String)o);
|
||||||
|
}
|
||||||
|
writer.endObject();
|
||||||
|
}
|
||||||
|
writer.endArray();
|
||||||
|
return sw.toString();
|
||||||
|
} catch (final IOException e) {
|
||||||
|
} finally {
|
||||||
|
close(writer);
|
||||||
|
}
|
||||||
|
return EMPTY_STRING;
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void close(final Closeable closeable) {
|
||||||
|
try {
|
||||||
|
if (closeable != null) {
|
||||||
|
closeable.close();
|
||||||
|
}
|
||||||
|
} catch (final IOException e) {
|
||||||
|
// Ignore
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -17,20 +17,14 @@
|
||||||
package com.android.inputmethod.latin.utils;
|
package com.android.inputmethod.latin.utils;
|
||||||
|
|
||||||
import android.text.TextUtils;
|
import android.text.TextUtils;
|
||||||
import android.util.JsonReader;
|
|
||||||
import android.util.JsonWriter;
|
|
||||||
import android.util.Log;
|
import android.util.Log;
|
||||||
|
|
||||||
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.settings.SettingsValues;
|
import com.android.inputmethod.latin.settings.SettingsValues;
|
||||||
|
|
||||||
import java.io.Closeable;
|
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.io.StringReader;
|
|
||||||
import java.io.StringWriter;
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.Collections;
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Locale;
|
import java.util.Locale;
|
||||||
|
|
||||||
|
@ -426,72 +420,4 @@ public final class StringUtils {
|
||||||
}
|
}
|
||||||
return bytes;
|
return bytes;
|
||||||
}
|
}
|
||||||
|
|
||||||
private static final String INTEGER_CLASS_NAME = Integer.class.getSimpleName();
|
|
||||||
private static final String STRING_CLASS_NAME = String.class.getSimpleName();
|
|
||||||
|
|
||||||
public static List<Object> jsonStrToList(final String s) {
|
|
||||||
final ArrayList<Object> list = CollectionUtils.newArrayList();
|
|
||||||
final JsonReader reader = new JsonReader(new StringReader(s));
|
|
||||||
try {
|
|
||||||
reader.beginArray();
|
|
||||||
while (reader.hasNext()) {
|
|
||||||
reader.beginObject();
|
|
||||||
while (reader.hasNext()) {
|
|
||||||
final String name = reader.nextName();
|
|
||||||
if (name.equals(INTEGER_CLASS_NAME)) {
|
|
||||||
list.add(reader.nextInt());
|
|
||||||
} else if (name.equals(STRING_CLASS_NAME)) {
|
|
||||||
list.add(reader.nextString());
|
|
||||||
} else {
|
|
||||||
Log.w(TAG, "Invalid name: " + name);
|
|
||||||
reader.skipValue();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
reader.endObject();
|
|
||||||
}
|
|
||||||
reader.endArray();
|
|
||||||
return list;
|
|
||||||
} catch (final IOException e) {
|
|
||||||
} finally {
|
|
||||||
close(reader);
|
|
||||||
}
|
|
||||||
return Collections.<Object>emptyList();
|
|
||||||
}
|
|
||||||
|
|
||||||
public static String listToJsonStr(final List<Object> list) {
|
|
||||||
if (list == null || list.isEmpty()) {
|
|
||||||
return EMPTY_STRING;
|
|
||||||
}
|
|
||||||
final StringWriter sw = new StringWriter();
|
|
||||||
final JsonWriter writer = new JsonWriter(sw);
|
|
||||||
try {
|
|
||||||
writer.beginArray();
|
|
||||||
for (final Object o : list) {
|
|
||||||
writer.beginObject();
|
|
||||||
if (o instanceof Integer) {
|
|
||||||
writer.name(INTEGER_CLASS_NAME).value((Integer)o);
|
|
||||||
} else if (o instanceof String) {
|
|
||||||
writer.name(STRING_CLASS_NAME).value((String)o);
|
|
||||||
}
|
|
||||||
writer.endObject();
|
|
||||||
}
|
|
||||||
writer.endArray();
|
|
||||||
return sw.toString();
|
|
||||||
} catch (final IOException e) {
|
|
||||||
} finally {
|
|
||||||
close(writer);
|
|
||||||
}
|
|
||||||
return EMPTY_STRING;
|
|
||||||
}
|
|
||||||
|
|
||||||
private static void close(final Closeable closeable) {
|
|
||||||
try {
|
|
||||||
if (closeable != null) {
|
|
||||||
closeable.close();
|
|
||||||
}
|
|
||||||
} catch (final IOException e) {
|
|
||||||
// Ignore
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -26,7 +26,7 @@ import java.util.List;
|
||||||
import java.util.Locale;
|
import java.util.Locale;
|
||||||
|
|
||||||
@SmallTest
|
@SmallTest
|
||||||
public class StringUtilsTests extends AndroidTestCase {
|
public class StringAndJsonUtilsTests extends AndroidTestCase {
|
||||||
public void testContainsInArray() {
|
public void testContainsInArray() {
|
||||||
assertFalse("empty array", StringUtils.containsInArray("key", new String[0]));
|
assertFalse("empty array", StringUtils.containsInArray("key", new String[0]));
|
||||||
assertFalse("not in 1 element", StringUtils.containsInArray("key", new String[] {
|
assertFalse("not in 1 element", StringUtils.containsInArray("key", new String[] {
|
||||||
|
@ -292,11 +292,11 @@ public class StringUtilsTests extends AndroidTestCase {
|
||||||
assertTrue(bytesStr.equals(bytesStr2));
|
assertTrue(bytesStr.equals(bytesStr2));
|
||||||
}
|
}
|
||||||
|
|
||||||
public void testJsonStringUtils() {
|
public void testJsonUtils() {
|
||||||
final Object[] objs = new Object[] { 1, "aaa", "bbb", 3 };
|
final Object[] objs = new Object[] { 1, "aaa", "bbb", 3 };
|
||||||
final List<Object> objArray = Arrays.asList(objs);
|
final List<Object> objArray = Arrays.asList(objs);
|
||||||
final String str = StringUtils.listToJsonStr(objArray);
|
final String str = JsonUtils.listToJsonStr(objArray);
|
||||||
final List<Object> newObjArray = StringUtils.jsonStrToList(str);
|
final List<Object> newObjArray = JsonUtils.jsonStrToList(str);
|
||||||
for (int i = 0; i < objs.length; ++i) {
|
for (int i = 0; i < objs.length; ++i) {
|
||||||
assertEquals(objs[i], newObjArray.get(i));
|
assertEquals(objs[i], newObjArray.get(i));
|
||||||
}
|
}
|
Loading…
Reference in a new issue