All Downloads are FREE. Search and download functionalities are using the official Maven repository.

io.github.humbleui.skija.impl.Log Maven / Gradle / Ivy

There is a newer version: 0.116.2
Show newest version
package io.github.humbleui.skija.impl;

import java.time.*;
import java.time.format.*;
import java.util.*;
import java.util.function.*;
import org.jetbrains.annotations.*;

public class Log {
    @ApiStatus.Internal
    public static final int _level;

    static { 
        String property = System.getProperty("skija.logLevel");
        if ("ALL".equals(property))
            _level = 0;
        else if("TRACE".equals(property))
            _level = 1;
        else if("DEBUG".equals(property))
            _level = 2;
        else if("INFO".equals(property))
            _level = 3;
        else if(null == property || "WARN".equals(property))
            _level = 4;
        else if("ERROR".equals(property))
            _level = 5;
        else if("NONE".equals(property))
            _level = 6;
        else
            throw new IllegalArgumentException("Unknown log level: " + property);
    }

    public static void trace(String s) {
        _log(1, "[TRACE]", s);
    }

    public static void debug(String s) {
        _log(2, "[DEBUG]", s);
    }

    public static void info(String s) {
        _log(3, "[INFO ]", s);
    }

    public static void warn(String s) {
        _log(4, "[WARN ]", s);
    }

    public static void error(String s) {
        _log(5, "[ERROR]", s);
    }

    public static void trace(Supplier s) {
        _log(1, "[TRACE]", s);
    }

    public static void debug(Supplier s) {
        _log(2, "[DEBUG]", s);
    }

    public static void info(Supplier s) {
        _log(3, "[INFO ]", s);
    }

    public static void warn(Supplier s) {
        _log(4, "[WARN ]", s);
    }

    public static void error(Supplier s) {
        _log(5, "[ERROR]", s);
    }

    public static String _time() {
        return ZonedDateTime.now(ZoneOffset.UTC).format(DateTimeFormatter.ISO_INSTANT);
    }

    public static void _log(int level, String prefix, String s) {
        if (level >= _level)
            System.out.println(_time() + " " + prefix + " " + s);
    }

    public static void _log(int level, String prefix, Supplier s) {
        if (level >= _level)
            System.out.println(_time() + " " + prefix + " " + s.get());
    }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy