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