org/sonews/util/Log.java
author cli
Sat, 01 May 2010 14:27:30 +0200
changeset 28 15d14b110240
parent 16 5a4a41cfc0a3
child 29 60c237bb677a
permissions -rw-r--r--
Make mailinglist gateway more reliable, probably.
     1 /*
     2  *   SONEWS News Server
     3  *   see AUTHORS for the list of contributors
     4  *
     5  *   This program is free software: you can redistribute it and/or modify
     6  *   it under the terms of the GNU General Public License as published by
     7  *   the Free Software Foundation, either version 3 of the License, or
     8  *   (at your option) any later version.
     9  *
    10  *   This program is distributed in the hope that it will be useful,
    11  *   but WITHOUT ANY WARRANTY; without even the implied warranty of
    12  *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
    13  *   GNU General Public License for more details.
    14  *
    15  *   You should have received a copy of the GNU General Public License
    16  *   along with this program.  If not, see <http://www.gnu.org/licenses/>.
    17  */
    18 
    19 package org.sonews.util;
    20 
    21 import java.util.logging.Level;
    22 import java.util.logging.LogManager;
    23 import java.util.logging.Logger;
    24 import java.util.logging.SimpleFormatter;
    25 import java.util.logging.StreamHandler;
    26 import org.sonews.config.Config;
    27 
    28 /**
    29  * Provides logging and debugging methods.
    30  * @author Christian Lins
    31  * @since sonews/0.5.0
    32  */
    33 public class Log
    34 {
    35 
    36   public static final String MAIN = "main";
    37 
    38   static
    39   {
    40     Logger mainLogger = Logger.getLogger(MAIN);
    41     StreamHandler handler = new StreamHandler(System.out, new SimpleFormatter());
    42     Level level = Level.parse(Config.inst().get(Config.LOGLEVEL, "INFO"));
    43     handler.setLevel(level);
    44     mainLogger.addHandler(handler);
    45     mainLogger.setLevel(level);
    46     LogManager.getLogManager().addLogger(mainLogger);
    47   }
    48 
    49   public static Logger get()
    50   {
    51     return get(MAIN);
    52   }
    53 
    54   public static Logger get(String name)
    55   {
    56     Level level = Level.parse(Config.inst().get(Config.LOGLEVEL, "INFO"));
    57     Logger logger = LogManager.getLogManager().getLogger(name);
    58     logger.setLevel(level);
    59     return logger;
    60   }
    61 
    62 }