001    /**
002     *
003     * Copyright 2003-2004 The Apache Software Foundation
004     *
005     *  Licensed under the Apache License, Version 2.0 (the "License");
006     *  you may not use this file except in compliance with the License.
007     *  You may obtain a copy of the License at
008     *
009     *     http://www.apache.org/licenses/LICENSE-2.0
010     *
011     *  Unless required by applicable law or agreed to in writing, software
012     *  distributed under the License is distributed on an "AS IS" BASIS,
013     *  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
014     *  See the License for the specific language governing permissions and
015     *  limitations under the License.
016     */
017    
018    package org.apache.geronimo.system.logging.log4j;
019    
020    import org.apache.commons.logging.Log;
021    import org.apache.log4j.Level;
022    import org.apache.log4j.Logger;
023    
024    /**
025     * This log wrapper caches the trace, debug and info enabled flags.  The flags are updated
026     * by a single timer task for all logs.
027     *
028     * @version $Rev: 355877 $ $Date: 2005-12-10 18:48:27 -0800 (Sat, 10 Dec 2005) $
029     */
030    public final class CachingLog4jLog implements Log {
031        private final String FQCN = getClass().getName();
032        private Logger logger;
033        private boolean traceEnabled;
034        private boolean debugEnabled;
035        private boolean infoEnabled;
036    
037        public CachingLog4jLog(String name) {
038            logger = Logger.getLogger(name);
039            updateLevelInfo();
040        }
041    
042        public CachingLog4jLog(Logger logger) {
043            this.logger = logger;
044            updateLevelInfo();
045        }
046    
047        public boolean isTraceEnabled() {
048            return traceEnabled;
049        }
050    
051        public void trace(Object message) {
052            if (traceEnabled) {
053                logger.log(FQCN, XLevel.TRACE, message, null);
054            }
055        }
056    
057        public void trace(Object message, Throwable throwable) {
058            if (traceEnabled) {
059                logger.log(FQCN, XLevel.TRACE, message, throwable);
060            }
061        }
062    
063        public boolean isDebugEnabled() {
064            return debugEnabled;
065        }
066    
067        public void debug(Object message) {
068            if (debugEnabled) {
069                logger.log(FQCN, Level.DEBUG, message, null);
070            }
071        }
072    
073        public void debug(Object message, Throwable throwable) {
074            if (debugEnabled) {
075                logger.log(FQCN, Level.DEBUG, message, throwable);
076            }
077        }
078    
079        public boolean isInfoEnabled() {
080            return infoEnabled;
081        }
082    
083        public void info(Object message) {
084            if (infoEnabled) {
085                logger.log(FQCN, Level.INFO, message, null);
086            }
087        }
088    
089        public void info(Object message, Throwable throwable) {
090            if (infoEnabled) {
091                logger.log(FQCN, Level.INFO, message, throwable);
092            }
093        }
094    
095        public boolean isWarnEnabled() {
096            return logger.isEnabledFor(Level.WARN);
097        }
098    
099        public void warn(Object message) {
100            logger.log(FQCN, Level.WARN, message, null);
101        }
102    
103        public void warn(Object message, Throwable throwable) {
104            logger.log(FQCN, Level.WARN, message, throwable);
105        }
106    
107        public boolean isErrorEnabled() {
108            return logger.isEnabledFor(Level.ERROR);
109        }
110    
111        public void error(Object message) {
112            logger.log(FQCN, Level.ERROR, message, null);
113        }
114    
115        public void error(Object message, Throwable throwable) {
116            logger.log(FQCN, Level.ERROR, message, throwable);
117        }
118    
119        public boolean isFatalEnabled() {
120            return logger.isEnabledFor(Level.FATAL);
121        }
122    
123        public void fatal(Object message) {
124            logger.log(FQCN, Level.FATAL, message, null);
125        }
126    
127        public void fatal(Object message, Throwable throwable) {
128            logger.log(FQCN, Level.FATAL, message, throwable);
129        }
130    
131        public void updateLevelInfo() {
132            // This method is proposely not synchronized.
133            // The setting of a boolean is atomic so we don't have to worry about inconsistent state.
134            // Normally we would have to worry about an out of date cache running threads (SMP boxes),
135            // but this cache is not time critical (so don't worry about it).
136            traceEnabled = logger.isEnabledFor(XLevel.TRACE);
137            debugEnabled = logger.isDebugEnabled();
138            infoEnabled = logger.isInfoEnabled();
139        }
140    }