Initial version -- added millennium read funcionality
This commit is contained in:
@@ -0,0 +1,147 @@
|
||||
package com.google.android.gms.common.util;
|
||||
|
||||
import android.text.TextUtils;
|
||||
import com.google.android.gms.common.internal.Preconditions;
|
||||
import java.util.Iterator;
|
||||
import java.util.regex.Matcher;
|
||||
import java.util.regex.Pattern;
|
||||
import org.json.JSONArray;
|
||||
import org.json.JSONException;
|
||||
import org.json.JSONObject;
|
||||
|
||||
/* JADX INFO: compiled from: com.google.android.gms:play-services-basement@@18.3.0 */
|
||||
/* JADX INFO: loaded from: classes2.dex */
|
||||
public final class JsonUtils {
|
||||
private static final Pattern zza = Pattern.compile("\\\\.");
|
||||
private static final Pattern zzb = Pattern.compile("[\\\\\"/\b\f\n\r\t]");
|
||||
|
||||
private JsonUtils() {
|
||||
}
|
||||
|
||||
public static boolean areJsonValuesEquivalent(Object obj, Object obj2) {
|
||||
if (obj == null && obj2 == null) {
|
||||
return true;
|
||||
}
|
||||
if (obj == null || obj2 == null) {
|
||||
return false;
|
||||
}
|
||||
if ((obj instanceof JSONObject) && (obj2 instanceof JSONObject)) {
|
||||
JSONObject jSONObject = (JSONObject) obj;
|
||||
JSONObject jSONObject2 = (JSONObject) obj2;
|
||||
if (jSONObject.length() != jSONObject2.length()) {
|
||||
return false;
|
||||
}
|
||||
Iterator<String> itKeys = jSONObject.keys();
|
||||
while (itKeys.hasNext()) {
|
||||
String next = itKeys.next();
|
||||
if (!jSONObject2.has(next)) {
|
||||
return false;
|
||||
}
|
||||
try {
|
||||
Preconditions.checkNotNull(next);
|
||||
} catch (JSONException unused) {
|
||||
}
|
||||
if (!areJsonValuesEquivalent(jSONObject.get(next), jSONObject2.get(next))) {
|
||||
return false;
|
||||
}
|
||||
}
|
||||
return true;
|
||||
}
|
||||
if (!(obj instanceof JSONArray) || !(obj2 instanceof JSONArray)) {
|
||||
return obj.equals(obj2);
|
||||
}
|
||||
JSONArray jSONArray = (JSONArray) obj;
|
||||
JSONArray jSONArray2 = (JSONArray) obj2;
|
||||
if (jSONArray.length() != jSONArray2.length()) {
|
||||
return false;
|
||||
}
|
||||
for (int i = 0; i < jSONArray.length(); i++) {
|
||||
if (!areJsonValuesEquivalent(jSONArray.get(i), jSONArray2.get(i))) {
|
||||
return false;
|
||||
}
|
||||
}
|
||||
return true;
|
||||
}
|
||||
|
||||
public static String escapeString(String str) {
|
||||
if (TextUtils.isEmpty(str)) {
|
||||
return str;
|
||||
}
|
||||
Matcher matcher = zzb.matcher(str);
|
||||
StringBuffer stringBuffer = null;
|
||||
while (matcher.find()) {
|
||||
if (stringBuffer == null) {
|
||||
stringBuffer = new StringBuffer();
|
||||
}
|
||||
char cCharAt = matcher.group().charAt(0);
|
||||
if (cCharAt == '\f') {
|
||||
matcher.appendReplacement(stringBuffer, "\\\\f");
|
||||
} else if (cCharAt == '\r') {
|
||||
matcher.appendReplacement(stringBuffer, "\\\\r");
|
||||
} else if (cCharAt == '\"') {
|
||||
matcher.appendReplacement(stringBuffer, "\\\\\\\"");
|
||||
} else if (cCharAt == '/') {
|
||||
matcher.appendReplacement(stringBuffer, "\\\\/");
|
||||
} else if (cCharAt != '\\') {
|
||||
switch (cCharAt) {
|
||||
case '\b':
|
||||
matcher.appendReplacement(stringBuffer, "\\\\b");
|
||||
break;
|
||||
case '\t':
|
||||
matcher.appendReplacement(stringBuffer, "\\\\t");
|
||||
break;
|
||||
case '\n':
|
||||
matcher.appendReplacement(stringBuffer, "\\\\n");
|
||||
break;
|
||||
}
|
||||
} else {
|
||||
matcher.appendReplacement(stringBuffer, "\\\\\\\\");
|
||||
}
|
||||
}
|
||||
if (stringBuffer == null) {
|
||||
return str;
|
||||
}
|
||||
matcher.appendTail(stringBuffer);
|
||||
return stringBuffer.toString();
|
||||
}
|
||||
|
||||
public static String unescapeString(String str) {
|
||||
if (TextUtils.isEmpty(str)) {
|
||||
return str;
|
||||
}
|
||||
String strZza = zzc.zza(str);
|
||||
Matcher matcher = zza.matcher(strZza);
|
||||
StringBuffer stringBuffer = null;
|
||||
while (matcher.find()) {
|
||||
if (stringBuffer == null) {
|
||||
stringBuffer = new StringBuffer();
|
||||
}
|
||||
char cCharAt = matcher.group().charAt(1);
|
||||
if (cCharAt == '\"') {
|
||||
matcher.appendReplacement(stringBuffer, "\"");
|
||||
} else if (cCharAt == '/') {
|
||||
matcher.appendReplacement(stringBuffer, "/");
|
||||
} else if (cCharAt == '\\') {
|
||||
matcher.appendReplacement(stringBuffer, "\\\\");
|
||||
} else if (cCharAt == 'b') {
|
||||
matcher.appendReplacement(stringBuffer, "\b");
|
||||
} else if (cCharAt == 'f') {
|
||||
matcher.appendReplacement(stringBuffer, "\f");
|
||||
} else if (cCharAt == 'n') {
|
||||
matcher.appendReplacement(stringBuffer, "\n");
|
||||
} else if (cCharAt == 'r') {
|
||||
matcher.appendReplacement(stringBuffer, "\r");
|
||||
} else {
|
||||
if (cCharAt != 't') {
|
||||
throw new IllegalStateException("Found an escaped character that should never be.");
|
||||
}
|
||||
matcher.appendReplacement(stringBuffer, "\t");
|
||||
}
|
||||
}
|
||||
if (stringBuffer == null) {
|
||||
return strZza;
|
||||
}
|
||||
matcher.appendTail(stringBuffer);
|
||||
return stringBuffer.toString();
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user