/******************************************************************************* * 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; } }