liuxue
2021-07-29 7e2df20ccc7cdfb528d309369460a4f3d66afdf1
SdkProject/library/src/main/java/com/secondworld/sdk/utils/LogUtil.java
@@ -5,19 +5,6 @@
import com.secondworld.sdk.BuildConfig;
import java.io.File;
import java.text.SimpleDateFormat;
import java.util.Date;
import java.util.Locale;
import me.pqpo.librarylog4a.Level;
import me.pqpo.librarylog4a.Log4a;
import me.pqpo.librarylog4a.LogData;
import me.pqpo.librarylog4a.appender.AndroidAppender;
import me.pqpo.librarylog4a.appender.FileAppender;
import me.pqpo.librarylog4a.formatter.DateFileFormatter;
import me.pqpo.librarylog4a.interceptor.Interceptor;
import me.pqpo.librarylog4a.logger.AppenderLogger;
public class LogUtil {
@@ -25,76 +12,74 @@
    private static final boolean DEBUG = BuildConfig.DEBUG;
    private static final String GLOBAL_TAG = "H2EngineSDK";
    private static final String GLOBAL_TAG = "Unity-SDK";
    public static void Init(Context context) {
        int level = Level.VERBOSE;
        Interceptor wrapInterceptor = new Interceptor() {
            @Override
            public boolean intercept(LogData logData) {
                logData.tag = "-" + logData.tag + ":";
                return true;
            }
        };
        AndroidAppender androidAppender = new AndroidAppender.Builder()
                .setLevel(level)
                .addInterceptor(wrapInterceptor)
                .create();
        File logDir = new File(context.getExternalCacheDir() + "/logs/");
        String buffer_path = logDir.getAbsolutePath() + File.separator + ".logCache";
        String time = new SimpleDateFormat("yyyy_MM_dd", Locale.getDefault()).format(new Date());
        String log_path = logDir.getAbsolutePath() + File.separator + time + ".txt";
        FileAppender fileAppender = new FileAppender.Builder(context)
                .setLogFilePath(log_path)
                .setLevel(level)
                .addInterceptor(wrapInterceptor)
                .setBufferFilePath(buffer_path)
                .setFormatter(new DateFileFormatter())
                .setCompress(false)
                .setBufferSize(BUFFER_SIZE)
                .create();
        AppenderLogger logger = new AppenderLogger.Builder()
                .addAppender(fileAppender)
                .create();
        Log4a.setLogger(logger);
//        int level = Level.VERBOSE;
//        Interceptor wrapInterceptor = logData -> {
//            logData.tag = GLOBAL_TAG + "-" + logData.tag + ":";
//            return true;
//        };
//        AndroidAppender androidAppender = new AndroidAppender.Builder()
//                .setLevel(level)
//                .addInterceptor(wrapInterceptor)
//                .create();
//
//        File logDir = new File(context.getExternalCacheDir() + "/logs/");
//        String buffer_path = logDir.getAbsolutePath() + File.separator + ".logCache";
//        String time = new SimpleDateFormat("yyyy_MM_dd", Locale.getDefault()).format(new Date());
//        String log_path = logDir.getAbsolutePath() + File.separator + time + ".txt";
//        FileAppender fileAppender = new FileAppender.Builder(context)
//                .setLogFilePath(log_path)
//                .setLevel(level)
//                .addInterceptor(wrapInterceptor)
//                .setBufferFilePath(buffer_path)
//                .setFormatter(new DateFileFormatter())
//                .setCompress(false)
//                .setBufferSize(BUFFER_SIZE)
//                .create();
//
//        AppenderLogger logger = new AppenderLogger.Builder()
//                .addAppender(fileAppender)
////                .addAppender(androidAppender)
//                .create();
//
//        Log4a.setLogger(logger);
    }
    private static void print(int level, String tag, String msg, boolean debug) {
        if (DEBUG || debug)//控制台输出
            Log.println(level, String.format("%s-%s", GLOBAL_TAG, tag), msg);
        else//写入本地文件
            Log4a.println(level, tag, msg);
//        if (DEBUG || debug)//控制台输出
        Log.println(level, String.format("%s-%s", GLOBAL_TAG, tag), msg);
//        else//写入本地文件
//        Log4a.println(level, tag, msg);
    }
    public static void debug(String tag, String msg) {
        print(Level.ERROR, tag, msg, true);
        print(Log.ERROR, tag, msg, true);
    }
    public static void v(String tag, String msg) {
        print(Level.VERBOSE, tag, msg, false);
        print(Log.VERBOSE, tag, msg, false);
    }
    public static void d(String tag, String msg) {
        print(Level.DEBUG, tag, msg, false);
        print(Log.DEBUG, tag, msg, false);
    }
    public static void i(String tag, String msg) {
        print(Level.INFO, tag, msg, false);
        print(Log.INFO, tag, msg, false);
    }
    public static void w(String tag, String msg) {
        print(Level.WARN, tag, msg, false);
        print(Log.WARN, tag, msg, false);
    }
    public static void e(String tag, String msg) {
        print(Level.ERROR, tag, msg, false);
        print(Log.ERROR, tag, msg, false);
    }
    public static void e(String tag, Exception e) {
        print(Level.ERROR, tag, Log.getStackTraceString(e), false);
        print(Log.ERROR, tag, Log.getStackTraceString(e), false);
    }
}