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

org.bytedeco.javacpp.tools.Logger Maven / Gradle / Ivy

There is a newer version: 1.5.11
Show newest version
/*
 * Copyright (C) 2014-2015 Samuel Audet
 *
 * Licensed either under the Apache License, Version 2.0, or (at your option)
 * under the terms of the GNU General Public License as published by
 * the Free Software Foundation (subject to the "Classpath" exception),
 * either version 2, or any later version (collectively, the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *     http://www.apache.org/licenses/LICENSE-2.0
 *     http://www.gnu.org/licenses/
 *     http://www.gnu.org/software/classpath/license.html
 *
 * or as provided in the LICENSE.txt file that accompanied this code.
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

package org.bytedeco.javacpp.tools;

/**
 * A simple but extensible logging interface that dumps messages to the "standard" output streams by default.
 *
 * @author Samuel Audet
 */
public class Logger {
    /** If the "org.bytedeco.javacpp.logger" system property is set to "slf4j",
     *  returns new {@link Slf4jLogger#Slf4jLogger(Class)}, else returns new {@link #Logger()}. */
    public static Logger create(Class cls) {
        String s = System.getProperty("org.bytedeco.javacpp.logger", "").toLowerCase();
        if (s.equals("slf4j") || s.equals("slf4jlogger")) {
            return new Slf4jLogger(cls);
        } else {
            return new Logger();
        }
    }

    static boolean debug = false;
    static {
        String s = System.getProperty("org.bytedeco.javacpp.logger.debug", "false").toLowerCase();
        debug = s.equals("true") || s.equals("t") || s.equals("");
    }

    /** Returns the "org.bytedeco.javacpp.logger.debug" system property. */
    public boolean isDebugEnabled() { return debug; }
    /** Returns true. */
    public boolean isInfoEnabled()  { return true; }
    /** Returns true. */
    public boolean isWarnEnabled()  { return true; }
    /** Returns true. */
    public boolean isErrorEnabled() { return true; }

    /** Calls {@code System.out.println(s)}. */
    public void debug(String s) { System.out.println(s); }
    /** Calls {@code System.out.println(s)}. */
    public void info(String s)  { System.out.println(s); }
    /** Calls {@code System.err.println("Warning: " + s)}. */
    public void warn(String s)  { System.err.println("Warning: " + s); }
    /** Calls {@code System.err.println("Error: " + s)}. */
    public void error(String s) { System.err.println("Error: " + s); }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy