util: light logger initialization fixed
[idea/community.git] / platform / util-rt / src / com / intellij / openapi / diagnostic / LoggerRt.java
1 /*
2  * Copyright 2000-2015 JetBrains s.r.o.
3  *
4  * Licensed under the Apache License, Version 2.0 (the "License");
5  * you may not use this file except in compliance with the License.
6  * You may obtain a copy of the License at
7  *
8  * http://www.apache.org/licenses/LICENSE-2.0
9  *
10  * Unless required by applicable law or agreed to in writing, software
11  * distributed under the License is distributed on an "AS IS" BASIS,
12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13  * See the License for the specific language governing permissions and
14  * limitations under the License.
15  */
16 package com.intellij.openapi.diagnostic;
17
18 import org.jetbrains.annotations.NonNls;
19 import org.jetbrains.annotations.NotNull;
20 import org.jetbrains.annotations.Nullable;
21
22 import java.lang.reflect.Method;
23 import java.util.logging.Level;
24 import java.util.logging.Logger;
25
26 /**
27  * A wrapper which uses either IDE logging subsystem (if available) or java.util.logging.
28  *
29  * @since 12.0
30  */
31 public abstract class LoggerRt {
32   private interface Factory {
33     LoggerRt getInstance(@NotNull @NonNls final String category);
34   }
35
36   private static Factory ourFactory;
37
38   private synchronized static Factory getFactory() {
39     if (ourFactory == null) {
40       try {
41         ourFactory = new IdeaFactory();
42       }
43       catch (Throwable t) {
44         ourFactory = new JavaFactory();
45       }
46     }
47     return ourFactory;
48   }
49
50   @NotNull
51   public static LoggerRt getInstance(@NotNull @NonNls final String category) {
52     return getFactory().getInstance(category);
53   }
54
55   public void info(@Nullable @NonNls final String message) {
56     info(message, null);
57   }
58
59   public void info(@NotNull final Throwable t) {
60     info(t.getMessage(), t);
61   }
62
63   public void warn(@Nullable @NonNls final String message) {
64     warn(message, null);
65   }
66
67   public void warn(@NotNull final Throwable t) {
68     warn(t.getMessage(), t);
69   }
70
71   public void error(@Nullable @NonNls final String message) {
72     error(message, null);
73   }
74
75   public void error(@NotNull final Throwable t) {
76     error(t.getMessage(), t);
77   }
78
79   public abstract void info(@Nullable @NonNls final String message, @Nullable final Throwable t);
80   public abstract void warn(@Nullable @NonNls final String message, @Nullable final Throwable t);
81   public abstract void error(@Nullable @NonNls final String message, @Nullable final Throwable t);
82
83   private static class JavaFactory implements Factory {
84     @Override
85     public LoggerRt getInstance(@NotNull @NonNls final String category) {
86       final Logger logger = Logger.getLogger(category);
87       return new LoggerRt() {
88         @Override
89         public void info(@Nullable @NonNls final String message, @Nullable final Throwable t) {
90           logger.log(Level.INFO, message, t);
91         }
92
93         @Override
94         public void warn(@Nullable @NonNls final String message, @Nullable final Throwable t) {
95           logger.log(Level.WARNING, message, t);
96         }
97
98         @Override
99         public void error(@Nullable @NonNls final String message, @Nullable final Throwable t) {
100           logger.log(Level.SEVERE, message, t);
101         }
102       };
103     }
104   }
105
106   private static class IdeaFactory implements Factory {
107     private final Method myGetInstance;
108     private final Method myInfo;
109     private final Method myWarn;
110     private final Method myError;
111
112     private IdeaFactory() throws Exception {
113       final Class<?> loggerClass = Class.forName("com.intellij.openapi.diagnostic.Logger");
114       myGetInstance = loggerClass.getMethod("getInstance", String.class);
115       myGetInstance.setAccessible(true);
116       myInfo = loggerClass.getMethod("info", String.class, Throwable.class);
117       myInfo.setAccessible(true);
118       myWarn = loggerClass.getMethod("warn", String.class, Throwable.class);
119       myInfo.setAccessible(true);
120       myError = loggerClass.getMethod("error", String.class, Throwable.class);
121       myError.setAccessible(true);
122     }
123
124     @Override
125     public LoggerRt getInstance(@NotNull @NonNls final String category) {
126       try {
127         final Object logger = myGetInstance.invoke(null, category);
128         return new LoggerRt() {
129           @Override
130           public void info(@Nullable @NonNls final String message, @Nullable final Throwable t) {
131             try {
132               myInfo.invoke(logger, message, t);
133             }
134             catch (Exception ignored) { }
135           }
136
137           @Override
138           public void warn(@Nullable @NonNls final String message, @Nullable final Throwable t) {
139             try {
140               myWarn.invoke(logger, message, t);
141             }
142             catch (Exception ignored) { }
143           }
144
145           @Override
146           public void error(@Nullable @NonNls final String message, @Nullable final Throwable t) {
147             try {
148               myError.invoke(logger, message, t);
149             }
150             catch (Exception ignored) { }
151           }
152         };
153       }
154       catch (Exception e) {
155         throw new RuntimeException(e);
156       }
157     }
158   }
159 }