/******************************************************************************* * Copyright 2011 See AUTHORS file. * * Licensed under the Apache License, Version 2.0 (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 * * 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 com.badlogic.gdx.utils; import com.badlogic.gdx.Application; import com.badlogic.gdx.Gdx; /** * Simple logger that uses the {@link Application} logging facilities to output messages. The log level set with * {@link Application#setLogLevel(int)} overrides the log level set here. * * @author mzechner * @author Nathan Sweet */ public class Logger { static public final int NONE = 0; static public final int ERROR = 1; static public final int INFO = 2; static public final int DEBUG = 3; private final String tag; private int level; public Logger(String tag) { this(tag, ERROR); } public Logger(String tag, int level) { this.tag = tag; this.level = level; } public void debug(String message) { if (level >= DEBUG) Gdx.app.debug(tag, message); } public void debug(String message, Exception exception) { if (level >= DEBUG) Gdx.app.debug(tag, message, exception); } public void info(String message) { if (level >= INFO) Gdx.app.log(tag, message); } public void info(String message, Exception exception) { if (level >= INFO) Gdx.app.log(tag, message, exception); } public void error(String message) { if (level >= ERROR) Gdx.app.error(tag, message); } public void error(String message, Throwable exception) { if (level >= ERROR) Gdx.app.error(tag, message, exception); } /** * Sets the log level. {@link #NONE} will mute all log output. {@link #ERROR} will only let error messages through. * {@link #INFO} will let all non-debug messages through, and {@link #DEBUG} will let all messages through. * * @param level * {@link #NONE}, {@link #ERROR}, {@link #INFO}, {@link #DEBUG}. */ public void setLevel(int level) { this.level = level; } public int getLevel() { return level; } }