org/sonews/util/Log.java
author chris <chris@marvin>
Fri, 26 Jun 2009 16:48:50 +0200
changeset 1 6fceb66e1ad7
child 3 2fdc9cc89502
permissions -rw-r--r--
Hooray... sonews/0.5.0 final

HG: Enter commit message. Lines beginning with 'HG:' are removed.
HG: Remove all lines to abort the collapse operation.
     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 org.sonews.daemon.*;
    22 import java.util.Date;
    23 
    24 /**
    25  * Provides logging and debugging methods.
    26  * @author Christian Lins
    27  * @since sonews/0.5.0
    28  */
    29 public class Log
    30 {
    31   
    32   public static boolean isDebug()
    33   {
    34     // We must use BootstrapConfig here otherwise we come
    35     // into hell's kittchen when using the Logger within the
    36     // Database class.
    37     return BootstrapConfig.getInstance().get(BootstrapConfig.DEBUG, false);
    38   }
    39   
    40   /**
    41    * Writes the given message to the debug output.
    42    * @param msg A String message or an object.
    43    * @param If true this message is only shown if debug mode is enabled.
    44    */
    45   public static void msg(final Object msg, boolean debug)
    46   {
    47     if(isDebug() || !debug)
    48     {
    49       synchronized(System.out)
    50       {
    51         System.out.print(new Date().toString());
    52         System.out.print(": ");
    53         System.out.println(msg);
    54         System.out.flush();
    55       }
    56     }
    57   }
    58 
    59 }