觅伊 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;
    }
}