200c24af7ef4b220e663d8f3402ed2c9788f2c6d
[mir.git] / source / mir / log / LoggerEngine.java
1 /*
2  * Copyright (C) 2005 The Mir-coders group
3  *
4  * This file is part of Mir.
5  *
6  * Mir is free software; you can redistribute it and/or modify
7  * it under the terms of the GNU General Public License as published by
8  * the Free Software Foundation; either version 2 of the License, or
9  * (at your option) any later version.
10  *
11  * Mir is distributed in the hope that it will be useful,
12  * but WITHOUT ANY WARRANTY; without even the implied warranty of
13  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14  * GNU General Public License for more details.
15  *
16  * You should have received a copy of the GNU General Public License
17  * along with Mir; if not, write to the Free Software
18  * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
19  *
20  * In addition, as a special exception, The Mir-coders gives permission to link
21  * the code of this program with  any library licensed under the Apache Software License.
22  * You must obey the GNU General Public License in all respects for all of the code used
23  * other than the above mentioned libraries.  If you modify this file, you may extend this
24  * exception to your version of the file, but you are not obligated to do so.
25  * If you do not wish to do so, delete this exception statement from your version.
26  */
27 package mir.log;
28
29 import mir.config.MirPropertiesConfiguration;
30
31 public class LoggerEngine {
32   private static Logger loggerInstance;
33
34   static {
35     try {
36       String loggerClass = MirPropertiesConfiguration.instance().getString("Log.LogClass");
37       loggerInstance = (Logger) Class.forName(loggerClass).newInstance();
38     }
39     catch (java.lang.ClassNotFoundException cnfe) {
40       System.err.println("LoggerEngine was not able to initialize: class not found");
41       cnfe.printStackTrace(System.err);
42     }
43     catch (java.lang.InstantiationException ie) {
44       System.err.println(
45           "LoggerEngine was not able to initialize: could not initialize class");
46       ie.printStackTrace(System.err);
47     }
48     catch (java.lang.IllegalAccessException iae) {
49       System.err.println("LoggerEngine was not able to initialize: illegal access");
50       iae.printStackTrace(System.err);
51     }
52   }
53
54   public static void debug(Object o, String s) {
55     loggerInstance.debug(o, s);
56   }
57
58   public static void info(Object o, String s) {
59     loggerInstance.info(o, s);
60   }
61
62   public static void warn(Object o, String s) {
63     loggerInstance.warn(o, s);
64   }
65
66   public static void warn(Object o, String s, Throwable anException) {
67     loggerInstance.warn(o, s, anException);
68   }
69
70   public static void error(Object o, String s) {
71     loggerInstance.error(o, s);
72   }
73
74   public static void error(Object o, String s, Throwable anException) {
75     loggerInstance.error(o, s, anException);
76   }
77
78   public static void fatal(Object o, String s) {
79     loggerInstance.fatal(o, s);
80   }
81
82   public static void reload() throws LoggerExc, LoggerFailure {
83     loggerInstance.reload();
84   }
85 }