chris@1: /*
chris@1:  *   SONEWS News Server
chris@1:  *   see AUTHORS for the list of contributors
chris@1:  *
chris@1:  *   This program is free software: you can redistribute it and/or modify
chris@1:  *   it under the terms of the GNU General Public License as published by
chris@1:  *   the Free Software Foundation, either version 3 of the License, or
chris@1:  *   (at your option) any later version.
chris@1:  *
chris@1:  *   This program is distributed in the hope that it will be useful,
chris@1:  *   but WITHOUT ANY WARRANTY; without even the implied warranty of
chris@1:  *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
chris@1:  *   GNU General Public License for more details.
chris@1:  *
chris@1:  *   You should have received a copy of the GNU General Public License
chris@1:  *   along with this program.  If not, see <http://www.gnu.org/licenses/>.
chris@1:  */
chris@1: 
chris@1: package org.sonews.util;
chris@1: 
cli@15: import java.util.logging.Level;
cli@15: import java.util.logging.LogManager;
cli@15: import java.util.logging.Logger;
cli@15: import java.util.logging.SimpleFormatter;
cli@15: import java.util.logging.StreamHandler;
chris@3: import org.sonews.config.Config;
chris@1: 
chris@1: /**
chris@1:  * Provides logging and debugging methods.
chris@1:  * @author Christian Lins
chris@1:  * @since sonews/0.5.0
chris@1:  */
cli@29: public class Log extends Logger
chris@1: {
cli@15: 
cli@37: 	private static Log instance = new Log();
cli@15: 
cli@37: 	private Log()
cli@37: 	{
cli@37: 		super("org.sonews", null);
cli@29: 
cli@37: 		StreamHandler handler = new StreamHandler(System.out, new SimpleFormatter());
cli@37: 		Level level = Level.parse(Config.inst().get(Config.LOGLEVEL, "INFO"));
cli@37: 		handler.setLevel(level);
cli@37: 		addHandler(handler);
cli@37: 		setLevel(level);
cli@37: 		LogManager.getLogManager().addLogger(this);
cli@37: 	}
cli@15: 
cli@37: 	public static Logger get()
cli@37: 	{
cli@37: 		Level level = Level.parse(Config.inst().get(Config.LOGLEVEL, "INFO"));
cli@37: 		instance.setLevel(level);
cli@37: 		return instance;
cli@37: 	}
chris@1: }