觅伊 v4.1.7版本的 MD5 值为:2a9d9e87c53524c098d85b78a90aa398
以下内容为反编译后的 KitReleaseLogUtils.java 源代码,内容仅作参考
package com.wind.imlib.utils;
import android.content.ClipData;
import android.content.ComponentName;
import android.content.Intent;
import android.graphics.Rect;
import android.net.Uri;
import android.os.Build;
import android.os.Bundle;
import android.util.Log;
import androidx.collection.SimpleArrayMap;
import com.google.gson.Gson;
import com.google.gson.GsonBuilder;
import com.meizu.cloud.pushsdk.notification.model.NotifyType;
import com.wind.imlib.WindClient;
import com.xiaomi.mipush.sdk.Constants;
import java.io.BufferedWriter;
import java.io.File;
import java.io.FileWriter;
import java.io.FilenameFilter;
import java.io.IOException;
import java.io.StringReader;
import java.io.StringWriter;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.reflect.ParameterizedType;
import java.lang.reflect.Type;
import java.text.ParseException;
import java.text.SimpleDateFormat;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.Collections;
import java.util.Date;
import java.util.Formatter;
import java.util.Iterator;
import java.util.List;
import java.util.Locale;
import java.util.Set;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
import java.util.regex.Matcher;
import java.util.regex.Pattern;
import javax.xml.transform.Transformer;
import javax.xml.transform.TransformerFactory;
import javax.xml.transform.stream.StreamResult;
import javax.xml.transform.stream.StreamSource;
import org.apache.commons.lang3.BooleanUtils;
import org.apache.commons.lang3.time.DateUtils;
import org.json.JSONArray;
import org.json.JSONException;
import org.json.JSONObject;
public class KitReleaseLogUtils {
public static final int A = 7;
private static final String ARGS = "args";
private static final String BOTTOM_BORDER = "└────────────────────────────────────────────────────────────────────────────────────────────────────────────────";
private static final String BOTTOM_CORNER = "└";
public static final int D = 3;
public static final int E = 6;
private static final int FILE = 16;
public static final int I = 4;
private static final int JSON = 32;
private static final String LEFT_BORDER = "│ ";
private static final int MAX_LEN = 1100;
private static final String MIDDLE_BORDER = "├┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄";
private static final String MIDDLE_CORNER = "├";
private static final String MIDDLE_DIVIDER = "┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄";
private static final String NOTHING = "log nothing";
private static final String NULL = "null";
private static final String PLACEHOLDER = " ";
private static final String SIDE_DIVIDER = "────────────────────────────────────────────────────────";
private static final String TOP_BORDER = "┌────────────────────────────────────────────────────────────────────────────────────────────────────────────────";
private static final String TOP_CORNER = "┌";
public static final int V = 2;
public static final int W = 5;
private static final int XML = 48;
private static SimpleDateFormat simpleDateFormat;
private static final char[] T = {'V', 'D', 'I', 'W', 'E', 'A'};
private static final String FILE_SEP = System.getProperty("file.separator");
private static final String LINE_SEP = System.getProperty("line.separator");
private static final Config CONFIG = new Config();
private static final ExecutorService EXECUTOR = Executors.newSingleThreadExecutor();
private static final SimpleArrayMap<Class, IFormatter> I_FORMATTER_MAP = new SimpleArrayMap<>();
public interface IFileWriter {
void write(String file, String content);
}
public static abstract class IFormatter<T> {
public abstract String format(T t);
}
@Retention(RetentionPolicy.SOURCE)
public @interface TYPE {
}
private KitReleaseLogUtils() {
throw new UnsupportedOperationException("u can't instantiate me...");
}
public static Config getConfig() {
return CONFIG;
}
public static void v(final Object... contents) {
log(2, CONFIG.getGlobalTag(), contents);
}
public static void vTag(final String tag, final Object... contents) {
log(2, tag, contents);
}
public static void d(final Object... contents) {
log(3, CONFIG.getGlobalTag(), contents);
}
public static void dTag(final String tag, final Object... contents) {
log(3, tag, contents);
}
public static void i(final Object... contents) {
log(4, CONFIG.getGlobalTag(), contents);
}
public static void iTag(final String tag, final Object... contents) {
log(4, tag, contents);
}
public static void w(final Object... contents) {
log(5, CONFIG.getGlobalTag(), contents);
}
public static void wTag(final String tag, final Object... contents) {
log(5, tag, contents);
}
public static void e(final Object... contents) {
log(6, CONFIG.getGlobalTag(), contents);
}
public static void eTag(final String tag, final Object... contents) {
log(6, tag, contents);
}
public static void a(final Object... contents) {
log(7, CONFIG.getGlobalTag(), contents);
}
public static void aTag(final String tag, final Object... contents) {
log(7, tag, contents);
}
public static void file(final Object content) {
log(19, CONFIG.getGlobalTag(), content);
}
public static void file(final int type, final Object content) {
log(type | 16, CONFIG.getGlobalTag(), content);
}
public static void file(final String tag, final Object content) {
log(19, tag, content);
}
public static void file(final int type, final String tag, final Object content) {
log(type | 16, tag, content);
}
public static void json(final Object content) {
log(35, CONFIG.getGlobalTag(), content);
}
public static void json(final int type, final Object content) {
log(type | 32, CONFIG.getGlobalTag(), content);
}
public static void json(final String tag, final Object content) {
log(35, tag, content);
}
public static void json(final int type, final String tag, final Object content) {
log(type | 32, tag, content);
}
public static void xml(final String content) {
log(51, CONFIG.getGlobalTag(), content);
}
public static void xml(final int type, final String content) {
log(type | 48, CONFIG.getGlobalTag(), content);
}
public static void xml(final String tag, final String content) {
log(51, tag, content);
}
public static void xml(final int type, final String tag, final String content) {
log(type | 48, tag, content);
}
public static void log(final int type, final String tag, final Object... contents) {
Config config = CONFIG;
if (config.isLogSwitch()) {
final int i = type & 15;
int i2 = type & 240;
if (config.isLog2ConsoleSwitch() || config.isLog2FileSwitch() || i2 == 16) {
if (i >= config.mConsoleFilter || i >= config.mFileFilter) {
final TagHead processTagAndHead = processTagAndHead(tag);
final String processBody = processBody(i2, contents);
if (config.isLog2ConsoleSwitch() && i2 != 16 && i >= config.mConsoleFilter) {
print2Console(i, processTagAndHead.tag, processTagAndHead.consoleHead, processBody);
}
if ((config.isLog2FileSwitch() || i2 == 16) && i >= config.mFileFilter) {
EXECUTOR.execute(new Runnable() {
@Override
public void run() {
int i3 = i;
String str = processTagAndHead.tag;
KitReleaseLogUtils.print2File(i3, str, processTagAndHead.fileHead + processBody);
}
});
}
}
}
}
}
public static List<File> getLogFiles() {
File file = new File(CONFIG.getDir());
if (file.exists()) {
File[] listFiles = file.listFiles(new FilenameFilter() {
@Override
public boolean accept(File dir, String name) {
return KitReleaseLogUtils.isMatchLogFileName(name);
}
});
ArrayList arrayList = new ArrayList();
Collections.addAll(arrayList, listFiles);
return arrayList;
}
return new ArrayList();
}
private static TagHead processTagAndHead(String tag) {
Config config = CONFIG;
if (!config.mTagIsSpace && !config.isLogHeadSwitch()) {
tag = config.getGlobalTag();
} else {
StackTraceElement[] stackTrace = new Throwable().getStackTrace();
int stackOffset = config.getStackOffset() + 3;
if (stackOffset >= stackTrace.length) {
String fileName = getFileName(stackTrace[3]);
if (config.mTagIsSpace && isSpace(tag)) {
int indexOf = fileName.indexOf(46);
tag = indexOf == -1 ? fileName : fileName.substring(0, indexOf);
}
return new TagHead(tag, null, ": ");
}
String fileName2 = getFileName(stackTrace[stackOffset]);
if (config.mTagIsSpace && isSpace(tag)) {
int indexOf2 = fileName2.indexOf(46);
tag = indexOf2 == -1 ? fileName2 : fileName2.substring(0, indexOf2);
}
if (config.isLogHeadSwitch()) {
String name = Thread.currentThread().getName();
String str = " [" + name + "]: ";
if (config.getStackDeep() <= 1) {
return new TagHead(tag, new String[]{name}, str);
}
int min = Math.min(config.getStackDeep(), stackTrace.length - stackOffset);
String[] strArr = new String[min];
strArr[0] = name;
String formatter = new Formatter().format("%" + (name.length() + 2) + NotifyType.SOUND, "").toString();
for (int i = 1; i < min; i++) {
StackTraceElement stackTraceElement = stackTrace[i + stackOffset];
strArr[i] = new Formatter().format("%s%s.%s(%s:%d)", formatter, stackTraceElement.getClassName(), stackTraceElement.getMethodName(), getFileName(stackTraceElement), Integer.valueOf(stackTraceElement.getLineNumber())).toString();
}
return new TagHead(tag, strArr, str);
}
}
return new TagHead(tag, null, ": ");
}
private static String getFileName(final StackTraceElement targetElement) {
String fileName = targetElement.getFileName();
if (fileName != null) {
return fileName;
}
String className = targetElement.getClassName();
String[] split = className.split("\\.");
if (split.length > 0) {
className = split[split.length - 1];
}
int indexOf = className.indexOf(36);
if (indexOf != -1) {
className = className.substring(0, indexOf);
}
return className + ".java";
}
private static String processBody(final int type, final Object... contents) {
String str;
if (contents != null) {
if (contents.length == 1) {
str = formatObject(type, contents[0]);
} else {
StringBuilder sb = new StringBuilder();
int length = contents.length;
for (int i = 0; i < length; i++) {
Object obj = contents[i];
sb.append(ARGS);
sb.append("[");
sb.append(i);
sb.append("]");
sb.append(" = ");
sb.append(formatObject(obj));
sb.append(LINE_SEP);
}
str = sb.toString();
}
} else {
str = NULL;
}
return str.length() == 0 ? NOTHING : str;
}
private static String formatObject(int type, Object object) {
if (object == null) {
return NULL;
}
if (type == 32) {
return LogFormatter.object2String(object, 32);
}
if (type == 48) {
return LogFormatter.object2String(object, 48);
}
return formatObject(object);
}
public static String formatObject(Object object) {
IFormatter iFormatter;
if (object == null) {
return NULL;
}
SimpleArrayMap<Class, IFormatter> simpleArrayMap = I_FORMATTER_MAP;
if (!simpleArrayMap.isEmpty() && (iFormatter = simpleArrayMap.get(getClassFromObject(object))) != null) {
return iFormatter.format(object);
}
return LogFormatter.object2String(object);
}
private static void print2Console(final int type, final String tag, final String[] head, final String msg) {
if (CONFIG.isSingleTagSwitch()) {
printSingleTagMsg(type, tag, processSingleTagMsg(type, tag, head, msg));
return;
}
printBorder(type, tag, true);
printHead(type, tag, head);
printMsg(type, tag, msg);
printBorder(type, tag, false);
}
private static void printBorder(final int type, final String tag, boolean isTop) {
if (CONFIG.isLogBorderSwitch()) {
Log.println(type, tag, isTop ? TOP_BORDER : BOTTOM_BORDER);
}
}
private static void printHead(final int type, final String tag, final String[] head) {
if (head != null) {
for (String str : head) {
if (CONFIG.isLogBorderSwitch()) {
str = LEFT_BORDER + str;
}
Log.println(type, tag, str);
}
if (CONFIG.isLogBorderSwitch()) {
Log.println(type, tag, MIDDLE_BORDER);
}
}
}
private static void printMsg(final int type, final String tag, final String msg) {
int length = msg.length();
int i = length / 1100;
if (i <= 0) {
printSubMsg(type, tag, msg);
return;
}
int i2 = 0;
int i3 = 0;
while (i2 < i) {
int i4 = i3 + 1100;
printSubMsg(type, tag, msg.substring(i3, i4));
i2++;
i3 = i4;
}
if (i3 != length) {
printSubMsg(type, tag, msg.substring(i3, length));
}
}
private static void printSubMsg(final int type, final String tag, final String msg) {
String[] split;
if (!CONFIG.isLogBorderSwitch()) {
Log.println(type, tag, msg);
return;
}
for (String str : msg.split(LINE_SEP)) {
Log.println(type, tag, LEFT_BORDER + str);
}
}
private static String processSingleTagMsg(final int type, final String tag, final String[] head, final String msg) {
StringBuilder sb = new StringBuilder();
int i = 0;
if (CONFIG.isLogBorderSwitch()) {
sb.append(" ");
String str = LINE_SEP;
sb.append(str);
sb.append(TOP_BORDER);
sb.append(str);
if (head != null) {
for (String str2 : head) {
sb.append(LEFT_BORDER);
sb.append(str2);
sb.append(LINE_SEP);
}
sb.append(MIDDLE_BORDER);
sb.append(LINE_SEP);
}
String[] split = msg.split(LINE_SEP);
int length = split.length;
while (i < length) {
String str3 = split[i];
sb.append(LEFT_BORDER);
sb.append(str3);
sb.append(LINE_SEP);
i++;
}
sb.append(BOTTOM_BORDER);
} else {
if (head != null) {
sb.append(" ");
sb.append(LINE_SEP);
int length2 = head.length;
while (i < length2) {
sb.append(head[i]);
sb.append(LINE_SEP);
i++;
}
}
sb.append(msg);
}
return sb.toString();
}
private static void printSingleTagMsg(final int type, final String tag, final String msg) {
int length = msg.length();
Config config = CONFIG;
int i = 1100;
int i2 = config.isLogBorderSwitch() ? (length - 113) / 1100 : length / 1100;
if (i2 > 0) {
int i3 = 1;
if (config.isLogBorderSwitch()) {
Log.println(type, tag, msg.substring(0, 1100) + LINE_SEP + BOTTOM_BORDER);
while (i3 < i2) {
StringBuilder sb = new StringBuilder();
sb.append(" ");
String str = LINE_SEP;
sb.append(str);
sb.append(TOP_BORDER);
sb.append(str);
sb.append(LEFT_BORDER);
int i4 = i + 1100;
sb.append(msg.substring(i, i4));
sb.append(str);
sb.append(BOTTOM_BORDER);
Log.println(type, tag, sb.toString());
i3++;
i = i4;
}
if (i != length - 113) {
StringBuilder sb2 = new StringBuilder();
sb2.append(" ");
String str2 = LINE_SEP;
sb2.append(str2);
sb2.append(TOP_BORDER);
sb2.append(str2);
sb2.append(LEFT_BORDER);
sb2.append(msg.substring(i, length));
Log.println(type, tag, sb2.toString());
return;
}
return;
}
Log.println(type, tag, msg.substring(0, 1100));
while (i3 < i2) {
StringBuilder sb3 = new StringBuilder();
sb3.append(" ");
sb3.append(LINE_SEP);
int i5 = i + 1100;
sb3.append(msg.substring(i, i5));
Log.println(type, tag, sb3.toString());
i3++;
i = i5;
}
if (i != length) {
Log.println(type, tag, " " + LINE_SEP + msg.substring(i, length));
return;
}
return;
}
Log.println(type, tag, msg);
}
public static void print2File(final int type, final String tag, final String msg) {
String format = getSdf().format(new Date());
String substring = format.substring(0, 10);
String substring2 = format.substring(11);
StringBuilder sb = new StringBuilder();
Config config = CONFIG;
sb.append(config.getDir());
sb.append(config.getFilePrefix());
sb.append("_");
sb.append(substring);
sb.append("_");
sb.append(config.getProcessName());
sb.append(config.getFileExtension());
String sb2 = sb.toString();
if (!createOrExistsFile(sb2, substring)) {
Log.e("LogUtils", "create " + sb2 + " failed!");
return;
}
input2File(substring2 + T[type - 2] + "/" + tag + msg + LINE_SEP, sb2);
}
private static SimpleDateFormat getSdf() {
if (simpleDateFormat == null) {
simpleDateFormat = new SimpleDateFormat("yyyy_MM_dd HH:mm:ss.SSS ", Locale.getDefault());
}
return simpleDateFormat;
}
private static boolean createOrExistsFile(final String filePath, final String date) {
File file = new File(filePath);
if (file.exists()) {
return file.isFile();
}
if (createOrExistsDir(file.getParentFile())) {
try {
deleteDueLogs(filePath, date);
boolean createNewFile = file.createNewFile();
if (createNewFile) {
printDeviceInfo(filePath, date);
}
return createNewFile;
} catch (IOException e) {
e.printStackTrace();
return false;
}
}
return false;
}
private static void deleteDueLogs(final String filePath, final String date) {
Config config;
File[] listFiles;
if (CONFIG.getSaveDays() > 0 && (listFiles = new File(filePath).getParentFile().listFiles(new FilenameFilter() {
@Override
public boolean accept(File dir, String name) {
return KitReleaseLogUtils.isMatchLogFileName(name);
}
})) != null && listFiles.length > 0) {
SimpleDateFormat simpleDateFormat2 = new SimpleDateFormat("yyyy_MM_dd", Locale.getDefault());
try {
long time = simpleDateFormat2.parse(date).getTime() - (config.getSaveDays() * DateUtils.MILLIS_PER_DAY);
for (final File file : listFiles) {
String name = file.getName();
name.length();
if (simpleDateFormat2.parse(findDate(name)).getTime() <= time) {
EXECUTOR.execute(new Runnable() {
@Override
public void run() {
if (file.delete()) {
return;
}
Log.e("LogUtils", "delete " + file + " failed!");
}
});
}
}
} catch (ParseException e) {
e.printStackTrace();
}
}
}
public static boolean isMatchLogFileName(String name) {
return name.matches("^" + CONFIG.getFilePrefix() + "_[0-9]{4}_[0-9]{2}_[0-9]{2}_.*$");
}
private static String findDate(String str) {
Matcher matcher = Pattern.compile("[0-9]{4}_[0-9]{2}_[0-9]{2}").matcher(str);
return matcher.find() ? matcher.group() : "";
}
private static void printDeviceInfo(final String filePath, final String date) {
input2File("************* Log Head ****************\nDate of Log : " + date + "\nDevice Manufacturer: " + Build.MANUFACTURER + "\nDevice Model : " + Build.MODEL + "\nAndroid Version : " + Build.VERSION.RELEASE + "\nAndroid SDK : " + Build.VERSION.SDK_INT + "\nApp VersionName : " + KitDeviceUtils.getAppVersionName() + "\nApp VersionCode : " + KitDeviceUtils.getAppVersionCode() + "\n************* Log Head ****************\n\n", filePath);
}
private static boolean createOrExistsDir(final File file) {
return file != null && (!file.exists() ? !file.mkdirs() : !file.isDirectory());
}
public static boolean isSpace(final String s) {
if (s == null) {
return true;
}
int length = s.length();
for (int i = 0; i < length; i++) {
if (!Character.isWhitespace(s.charAt(i))) {
return false;
}
}
return true;
}
private static void input2File(final String input, final String filePath) {
BufferedWriter bufferedWriter;
Config config = CONFIG;
if (config.mFileWriter == null) {
BufferedWriter bufferedWriter2 = null;
try {
try {
try {
bufferedWriter = new BufferedWriter(new FileWriter(filePath, true));
} catch (IOException e) {
e = e;
}
} catch (Throwable th) {
th = th;
}
try {
bufferedWriter.write(input);
bufferedWriter.close();
} catch (IOException e2) {
e = e2;
bufferedWriter2 = bufferedWriter;
e.printStackTrace();
Log.e("LogUtils", "log to " + filePath + " failed!");
if (bufferedWriter2 != null) {
bufferedWriter2.close();
return;
}
return;
} catch (Throwable th2) {
th = th2;
bufferedWriter2 = bufferedWriter;
if (bufferedWriter2 != null) {
try {
bufferedWriter2.close();
} catch (IOException e3) {
e3.printStackTrace();
}
}
throw th;
}
return;
} catch (IOException e4) {
e4.printStackTrace();
return;
}
}
config.mFileWriter.write(filePath, input);
}
public static final class Config {
private int mConsoleFilter;
private String mDefaultDir;
private String mDir;
private String mFileExtension;
private int mFileFilter;
private String mFilePrefix;
private IFileWriter mFileWriter;
private String mGlobalTag;
private boolean mLog2ConsoleSwitch;
private boolean mLog2FileSwitch;
private boolean mLogBorderSwitch;
private boolean mLogHeadSwitch;
private boolean mLogSwitch;
private String mProcessName;
private int mSaveDays;
private boolean mSingleTagSwitch;
private int mStackDeep;
private int mStackOffset;
private boolean mTagIsSpace;
private Config() {
this.mFilePrefix = "util";
this.mFileExtension = ".txt";
this.mLogSwitch = true;
this.mLog2ConsoleSwitch = true;
this.mGlobalTag = "";
this.mTagIsSpace = true;
this.mLogHeadSwitch = true;
this.mLog2FileSwitch = true;
this.mLogBorderSwitch = false;
this.mSingleTagSwitch = true;
this.mConsoleFilter = 2;
this.mFileFilter = 2;
this.mStackDeep = 1;
this.mStackOffset = 0;
this.mSaveDays = 7;
this.mProcessName = KitProcessUtils.getCurrentProcessName();
if (this.mDefaultDir != null) {
return;
}
this.mDefaultDir = WindClient.getApp().getCacheDir() + KitReleaseLogUtils.FILE_SEP + "log" + KitReleaseLogUtils.FILE_SEP;
}
public final Config setLogSwitch(final boolean logSwitch) {
this.mLogSwitch = logSwitch;
return this;
}
public final Config setConsoleSwitch(final boolean consoleSwitch) {
this.mLog2ConsoleSwitch = consoleSwitch;
return this;
}
public final Config setGlobalTag(final String tag) {
if (KitReleaseLogUtils.isSpace(tag)) {
this.mGlobalTag = "";
this.mTagIsSpace = true;
} else {
this.mGlobalTag = tag;
this.mTagIsSpace = false;
}
return this;
}
public final Config setLogHeadSwitch(final boolean logHeadSwitch) {
this.mLogHeadSwitch = logHeadSwitch;
return this;
}
public final Config setLog2FileSwitch(final boolean log2FileSwitch) {
this.mLog2FileSwitch = log2FileSwitch;
return this;
}
public final Config setDir(final String dir) {
if (!KitReleaseLogUtils.isSpace(dir)) {
if (!dir.endsWith(KitReleaseLogUtils.FILE_SEP)) {
dir = dir + KitReleaseLogUtils.FILE_SEP;
}
this.mDir = dir;
} else {
this.mDir = null;
}
return this;
}
public final Config setDir(final File dir) {
String str;
if (dir == null) {
str = null;
} else {
str = dir.getAbsolutePath() + KitReleaseLogUtils.FILE_SEP;
}
this.mDir = str;
return this;
}
public final Config setFilePrefix(final String filePrefix) {
if (KitReleaseLogUtils.isSpace(filePrefix)) {
this.mFilePrefix = "util";
} else {
this.mFilePrefix = filePrefix;
}
return this;
}
public final Config setFileExtension(final String fileExtension) {
if (KitReleaseLogUtils.isSpace(fileExtension)) {
this.mFileExtension = ".txt";
} else if (fileExtension.startsWith(".")) {
this.mFileExtension = fileExtension;
} else {
this.mFileExtension = "." + fileExtension;
}
return this;
}
public final Config setBorderSwitch(final boolean borderSwitch) {
this.mLogBorderSwitch = borderSwitch;
return this;
}
public final Config setSingleTagSwitch(final boolean singleTagSwitch) {
this.mSingleTagSwitch = singleTagSwitch;
return this;
}
public final Config setConsoleFilter(final int consoleFilter) {
this.mConsoleFilter = consoleFilter;
return this;
}
public final Config setFileFilter(final int fileFilter) {
this.mFileFilter = fileFilter;
return this;
}
public final Config setStackDeep(final int stackDeep) {
this.mStackDeep = stackDeep;
return this;
}
public final Config setStackOffset(final int stackOffset) {
this.mStackOffset = stackOffset;
return this;
}
public final Config setSaveDays(final int saveDays) {
this.mSaveDays = saveDays;
return this;
}
public final <T> Config addFormatter(final IFormatter<T> iFormatter) {
if (iFormatter != null) {
KitReleaseLogUtils.I_FORMATTER_MAP.put(KitReleaseLogUtils.getTypeClassFromParadigm(iFormatter), iFormatter);
}
return this;
}
public final Config setFileWriter(final IFileWriter fileWriter) {
this.mFileWriter = fileWriter;
return this;
}
public final String getProcessName() {
String str = this.mProcessName;
return str == null ? "" : str.replace(Constants.COLON_SEPARATOR, "_");
}
public final String getDefaultDir() {
return this.mDefaultDir;
}
public final String getDir() {
String str = this.mDir;
return str == null ? this.mDefaultDir : str;
}
public final String getFilePrefix() {
return this.mFilePrefix;
}
public final String getFileExtension() {
return this.mFileExtension;
}
public final boolean isLogSwitch() {
return this.mLogSwitch;
}
public final boolean isLog2ConsoleSwitch() {
return this.mLog2ConsoleSwitch;
}
public final String getGlobalTag() {
return KitReleaseLogUtils.isSpace(this.mGlobalTag) ? "" : this.mGlobalTag;
}
public final boolean isLogHeadSwitch() {
return this.mLogHeadSwitch;
}
public final boolean isLog2FileSwitch() {
return this.mLog2FileSwitch;
}
public final boolean isLogBorderSwitch() {
return this.mLogBorderSwitch;
}
public final boolean isSingleTagSwitch() {
return this.mSingleTagSwitch;
}
public final char getConsoleFilter() {
return KitReleaseLogUtils.T[this.mConsoleFilter - 2];
}
public final char getFileFilter() {
return KitReleaseLogUtils.T[this.mFileFilter - 2];
}
public final int getStackDeep() {
return this.mStackDeep;
}
public final int getStackOffset() {
return this.mStackOffset;
}
public final int getSaveDays() {
return this.mSaveDays;
}
public String toString() {
return "process: " + getProcessName() + KitReleaseLogUtils.LINE_SEP + "switch: " + isLogSwitch() + KitReleaseLogUtils.LINE_SEP + "console: " + isLog2ConsoleSwitch() + KitReleaseLogUtils.LINE_SEP + "tag: " + getGlobalTag() + KitReleaseLogUtils.LINE_SEP + "head: " + isLogHeadSwitch() + KitReleaseLogUtils.LINE_SEP + "file: " + isLog2FileSwitch() + KitReleaseLogUtils.LINE_SEP + "dir: " + getDir() + KitReleaseLogUtils.LINE_SEP + "filePrefix: " + getFilePrefix() + KitReleaseLogUtils.LINE_SEP + "border: " + isLogBorderSwitch() + KitReleaseLogUtils.LINE_SEP + "singleTag: " + isSingleTagSwitch() + KitReleaseLogUtils.LINE_SEP + "consoleFilter: " + getConsoleFilter() + KitReleaseLogUtils.LINE_SEP + "fileFilter: " + getFileFilter() + KitReleaseLogUtils.LINE_SEP + "stackDeep: " + getStackDeep() + KitReleaseLogUtils.LINE_SEP + "stackOffset: " + getStackOffset() + KitReleaseLogUtils.LINE_SEP + "saveDays: " + getSaveDays() + KitReleaseLogUtils.LINE_SEP + "formatter: " + KitReleaseLogUtils.I_FORMATTER_MAP;
}
}
public static final class TagHead {
String[] consoleHead;
String fileHead;
String tag;
TagHead(String tag, String[] consoleHead, String fileHead) {
this.tag = tag;
this.consoleHead = consoleHead;
this.fileHead = fileHead;
}
}
public static final class LogFormatter {
private static final Gson GSON = new GsonBuilder().setPrettyPrinting().serializeNulls().create();
private LogFormatter() {
}
static String object2String(Object object) {
return object2String(object, -1);
}
static String object2String(Object object, int type) {
if (object.getClass().isArray()) {
return array2String(object);
}
if (object instanceof Throwable) {
return throwable2String((Throwable) object);
}
if (object instanceof Bundle) {
return bundle2String((Bundle) object);
}
if (object instanceof Intent) {
return intent2String((Intent) object);
}
if (type == 32) {
return object2Json(object);
}
if (type == 48) {
return formatXml(object.toString());
}
return object.toString();
}
private static String throwable2String(final Throwable e) {
return KitThrowableUtils.getFullStackTrace(e);
}
private static String bundle2String(Bundle bundle) {
Iterator<String> it2 = bundle.keySet().iterator();
if (!it2.hasNext()) {
return "Bundle {}";
}
StringBuilder sb = new StringBuilder(128);
sb.append("Bundle { ");
while (true) {
String next = it2.next();
Object obj = bundle.get(next);
sb.append(next);
sb.append('=');
if (!(obj instanceof Bundle)) {
sb.append(KitReleaseLogUtils.formatObject(obj));
} else {
sb.append(obj == bundle ? "(this Bundle)" : bundle2String((Bundle) obj));
}
if (!it2.hasNext()) {
sb.append(" }");
return sb.toString();
}
sb.append(',');
sb.append(' ');
}
}
private static String intent2String(Intent intent) {
boolean z;
Intent selector;
ClipData clipData;
StringBuilder sb = new StringBuilder(128);
sb.append("Intent { ");
String action = intent.getAction();
boolean z2 = true;
boolean z3 = false;
if (action != null) {
sb.append("act=");
sb.append(action);
z = false;
} else {
z = true;
}
Set<String> categories = intent.getCategories();
if (categories != null) {
if (!z) {
sb.append(' ');
}
sb.append("cat=[");
for (String str : categories) {
if (!z2) {
sb.append(',');
}
sb.append(str);
z2 = false;
}
sb.append("]");
z = false;
}
Uri data = intent.getData();
if (data != null) {
if (!z) {
sb.append(' ');
}
sb.append("dat=");
sb.append(data);
z = false;
}
String type = intent.getType();
if (type != null) {
if (!z) {
sb.append(' ');
}
sb.append("typ=");
sb.append(type);
z = false;
}
int flags = intent.getFlags();
if (flags != 0) {
if (!z) {
sb.append(' ');
}
sb.append("flg=0x");
sb.append(Integer.toHexString(flags));
z = false;
}
String str2 = intent.getPackage();
if (str2 != null) {
if (!z) {
sb.append(' ');
}
sb.append("pkg=");
sb.append(str2);
z = false;
}
ComponentName component = intent.getComponent();
if (component != null) {
if (!z) {
sb.append(' ');
}
sb.append("cmp=");
sb.append(component.flattenToShortString());
z = false;
}
Rect sourceBounds = intent.getSourceBounds();
if (sourceBounds != null) {
if (!z) {
sb.append(' ');
}
sb.append("bnds=");
sb.append(sourceBounds.toShortString());
z = false;
}
if (Build.VERSION.SDK_INT >= 16 && (clipData = intent.getClipData()) != null) {
if (!z) {
sb.append(' ');
}
clipData2String(clipData, sb);
z = false;
}
Bundle extras = intent.getExtras();
if (extras != null) {
if (!z) {
sb.append(' ');
}
sb.append("extras={");
sb.append(bundle2String(extras));
sb.append('}');
} else {
z3 = z;
}
if (Build.VERSION.SDK_INT >= 15 && (selector = intent.getSelector()) != null) {
if (!z3) {
sb.append(' ');
}
sb.append("sel={");
sb.append(selector == intent ? "(this Intent)" : intent2String(selector));
sb.append("}");
}
sb.append(" }");
return sb.toString();
}
private static void clipData2String(ClipData clipData, StringBuilder sb) {
ClipData.Item itemAt = clipData.getItemAt(0);
if (itemAt == null) {
sb.append("ClipData.Item {}");
return;
}
sb.append("ClipData.Item { ");
String htmlText = itemAt.getHtmlText();
if (htmlText != null) {
sb.append("H:");
sb.append(htmlText);
sb.append("}");
return;
}
CharSequence text = itemAt.getText();
if (text != null) {
sb.append("T:");
sb.append(text);
sb.append("}");
return;
}
Uri uri = itemAt.getUri();
if (uri != null) {
sb.append("U:");
sb.append(uri);
sb.append("}");
return;
}
Intent intent = itemAt.getIntent();
if (intent != null) {
sb.append("I:");
sb.append(intent2String(intent));
sb.append("}");
return;
}
sb.append("NULL");
sb.append("}");
}
private static String object2Json(Object object) {
if (object instanceof CharSequence) {
return formatJson(object.toString());
}
try {
return GSON.toJson(object);
} catch (Throwable unused) {
return object.toString();
}
}
private static String formatJson(String json) {
try {
int length = json.length();
for (int i = 0; i < length; i++) {
char charAt = json.charAt(i);
if (charAt == '{') {
return new JSONObject(json).toString(2);
}
if (charAt == '[') {
return new JSONArray(json).toString(2);
}
if (!Character.isWhitespace(charAt)) {
return json;
}
}
} catch (JSONException e) {
e.printStackTrace();
}
return json;
}
private static String formatXml(String xml) {
try {
StreamSource streamSource = new StreamSource(new StringReader(xml));
StreamResult streamResult = new StreamResult(new StringWriter());
Transformer newTransformer = TransformerFactory.newInstance().newTransformer();
newTransformer.setOutputProperty("indent", BooleanUtils.YES);
newTransformer.setOutputProperty("{http://xml.apache.org/xslt}indent-amount", "2");
newTransformer.transform(streamSource, streamResult);
String obj = streamResult.getWriter().toString();
return obj.replaceFirst(">", ">" + KitReleaseLogUtils.LINE_SEP);
} catch (Exception e) {
e.printStackTrace();
return xml;
}
}
private static String array2String(Object object) {
if (object instanceof Object[]) {
return Arrays.deepToString((Object[]) object);
}
if (object instanceof boolean[]) {
return Arrays.toString((boolean[]) object);
}
if (object instanceof byte[]) {
return Arrays.toString((byte[]) object);
}
if (object instanceof char[]) {
return Arrays.toString((char[]) object);
}
if (object instanceof double[]) {
return Arrays.toString((double[]) object);
}
if (object instanceof float[]) {
return Arrays.toString((float[]) object);
}
if (object instanceof int[]) {
return Arrays.toString((int[]) object);
}
if (object instanceof long[]) {
return Arrays.toString((long[]) object);
}
if (object instanceof short[]) {
return Arrays.toString((short[]) object);
}
throw new IllegalArgumentException("Array has incompatible type: " + object.getClass());
}
}
public static <T> Class getTypeClassFromParadigm(final IFormatter<T> formatter) {
Type genericSuperclass;
Type[] genericInterfaces = formatter.getClass().getGenericInterfaces();
if (genericInterfaces.length == 1) {
genericSuperclass = genericInterfaces[0];
} else {
genericSuperclass = formatter.getClass().getGenericSuperclass();
}
Type type = ((ParameterizedType) genericSuperclass).getActualTypeArguments()[0];
while (type instanceof ParameterizedType) {
type = ((ParameterizedType) type).getRawType();
}
String obj = type.toString();
if (obj.startsWith("class ")) {
obj = obj.substring(6);
} else if (obj.startsWith("interface ")) {
obj = obj.substring(10);
}
try {
return Class.forName(obj);
} catch (ClassNotFoundException e) {
e.printStackTrace();
return null;
}
}
private static Class getClassFromObject(final Object obj) {
String obj2;
Class<?> cls = obj.getClass();
if (cls.isAnonymousClass() || cls.isSynthetic()) {
Type[] genericInterfaces = cls.getGenericInterfaces();
if (genericInterfaces.length == 1) {
Type type = genericInterfaces[0];
while (type instanceof ParameterizedType) {
type = ((ParameterizedType) type).getRawType();
}
obj2 = type.toString();
} else {
Type genericSuperclass = cls.getGenericSuperclass();
while (genericSuperclass instanceof ParameterizedType) {
genericSuperclass = ((ParameterizedType) genericSuperclass).getRawType();
}
obj2 = genericSuperclass.toString();
}
if (obj2.startsWith("class ")) {
obj2 = obj2.substring(6);
} else if (obj2.startsWith("interface ")) {
obj2 = obj2.substring(10);
}
try {
return Class.forName(obj2);
} catch (ClassNotFoundException e) {
e.printStackTrace();
}
}
return cls;
}
}