23863fe63f1c2fd6ba640bfa6f07747e6077489a
[idea/community.git] / platform / util-rt / src / com / intellij / openapi / diagnostic / LoggerRt.java
1 /*
2  * Copyright 2000-2012 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.LogManager;
25 import java.util.logging.Logger;
26
27 /**
28  * A wrapper which uses either IDE logging subsystem (if available) or java.util.logging.
29  *
30  * @since 12.0
31  */
32 public abstract class LoggerRt {
33   private interface Factory {
34     LoggerRt getInstance(@NotNull @NonNls final String category);
35   }
36
37   private static Factory ourFactory;
38
39   private synchronized static Factory getFactory() {
40     if (ourFactory == null) {
41       try {
42         ourFactory = new IdeaFactory();
43       }
44       catch (Throwable t) {
45         ourFactory = new JavaFactory();
46       }
47     }
48     return ourFactory;
49   }
50
51   @NotNull
52   public static LoggerRt getInstance(@NotNull @NonNls final String category) {
53     return getFactory().getInstance(category);
54   }
55
56   public void info(@Nullable @NonNls final String message) {
57     info(message, null);
58   }
59
60   public void info(@NotNull final Throwable t) {
61     info(t.getMessage(), t);
62   }
63
64   public void warn(@Nullable @NonNls final String message) {
65     warn(message, null);
66   }
67
68   public void warn(@NotNull final Throwable t) {
69     warn(t.getMessage(), t);
70   }
71
72   public void error(@Nullable @NonNls final String message) {
73     error(message, null);
74   }
75
76   public void error(@NotNull final Throwable t) {
77     error(t.getMessage(), t);
78   }
79
80   public abstract void info(@Nullable @NonNls final String message, @Nullable final Throwable t);
81   public abstract void warn(@Nullable @NonNls final String message, @Nullable final Throwable t);
82   public abstract void error(@Nullable @NonNls final String message, @Nullable final Throwable t);
83
84   private static class JavaFactory implements Factory {
85     private final LogManager myManager = LogManager.getLogManager();
86
87     public LoggerRt getInstance(@NotNull @NonNls final String category) {
88       final Logger logger = myManager.getLogger(category);
89       return new LoggerRt() {
90         @Override
91         public void info(@Nullable @NonNls final String message, @Nullable final Throwable t) {
92           logger.log(Level.INFO, message, t);
93         }
94
95         @Override
96         public void warn(@Nullable @NonNls final String message, @Nullable final Throwable t) {
97           logger.log(Level.WARNING, message, t);
98         }
99
100         @Override
101         public void error(@Nullable @NonNls final String message, @Nullable final Throwable t) {
102           logger.log(Level.SEVERE, message, t);
103         }
104       };
105     }
106   }
107
108   private static class IdeaFactory implements Factory {
109     private final Method myGetInstance;
110     private final Method myInfo;
111     private final Method myWarn;
112     private final Method myError;
113
114     private IdeaFactory() throws Exception {
115       final Class<?> loggerClass = Class.forName("com.intellij.openapi.diagnostic.Logger");
116       myGetInstance = loggerClass.getMethod("getInstance", String.class);
117       myGetInstance.setAccessible(true);
118       myInfo = loggerClass.getMethod("info", String.class, Throwable.class);
119       myInfo.setAccessible(true);
120       myWarn = loggerClass.getMethod("warn", String.class, Throwable.class);
121       myInfo.setAccessible(true);
122       myError = loggerClass.getMethod("error", String.class, Throwable.class);
123       myError.setAccessible(true);
124     }
125
126     public LoggerRt getInstance(@NotNull @NonNls final String category) {
127       try {
128         final Object logger = myGetInstance.invoke(null, category);
129         return new LoggerRt() {
130           @Override
131           public void info(@Nullable @NonNls final String message, @Nullable final Throwable t) {
132             try {
133               myInfo.invoke(logger, message, t);
134             }
135             catch (Exception ignored) { }
136           }
137
138           @Override
139           public void warn(@Nullable @NonNls final String message, @Nullable final Throwable t) {
140             try {
141               myWarn.invoke(logger, message, t);
142             }
143             catch (Exception ignored) { }
144           }
145
146           @Override
147           public void error(@Nullable @NonNls final String message, @Nullable final Throwable t) {
148             try {
149               myError.invoke(logger, message, t);
150             }
151             catch (Exception ignored) { }
152           }
153         };
154       }
155       catch (Exception e) {
156         throw new RuntimeException(e);
157       }
158     }
159   }
160 }