1 /* 2 * Copyright (c) 2004-2005 SLF4J.ORG 3 * Copyright (c) 2004-2005 QOS.ch 4 * 5 * All rights reserved. 6 * 7 * Permission is hereby granted, free of charge, to any person obtaining 8 * a copy of this software and associated documentation files (the 9 * "Software"), to deal in the Software without restriction, including 10 * without limitation the rights to use, copy, modify, merge, publish, 11 * distribute, and/or sell copies of the Software, and to permit persons 12 * to whom the Software is furnished to do so, provided that the above 13 * copyright notice(s) and this permission notice appear in all copies of 14 * the Software and that both the above copyright notice(s) and this 15 * permission notice appear in supporting documentation. 16 * 17 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, 18 * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF 19 * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT 20 * OF THIRD PARTY RIGHTS. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR 21 * HOLDERS INCLUDED IN THIS NOTICE BE LIABLE FOR ANY CLAIM, OR ANY 22 * SPECIAL INDIRECT OR CONSEQUENTIAL DAMAGES, OR ANY DAMAGES WHATSOEVER 23 * RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF 24 * CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN 25 * CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. 26 * 27 * Except as contained in this notice, the name of a copyright holder 28 * shall not be used in advertising or otherwise to promote the sale, use 29 * or other dealings in this Software without prior written authorization 30 * of the copyright holder. 31 * 32 */ 33 34 package org.slf4j.impl; 35 36 import java.util.HashMap; 37 import java.util.Map; 38 39 import org.apache.log4j.LogManager; 40 import org.slf4j.ILoggerFactory; 41 import org.slf4j.Logger; 42 43 /** 44 * Log4jLoggerFactory is an implementation of {@link ILoggerFactory} returning 45 * the appropriate named {@link Log4jLoggerAdapter} instance. 46 * 47 * @author Ceki Gülcü 48 */ 49 public class Log4jLoggerFactory implements ILoggerFactory { 50 51 // key: name (String), value: a Log4jLoggerAdapter; 52 Map loggerMap; 53 54 public Log4jLoggerFactory() { 55 loggerMap = new HashMap(); 56 } 57 58 /* 59 * (non-Javadoc) 60 * 61 * @see org.slf4j.ILoggerFactory#getLogger(java.lang.String) 62 */ 63 public Logger getLogger(String name) { 64 Logger slf4jLogger = null; 65 // protect against concurrent access of loggerMap 66 synchronized (this) { 67 slf4jLogger = (Logger) loggerMap.get(name); 68 if (slf4jLogger == null) { 69 org.apache.log4j.Logger log4jLogger; 70 if(name.equalsIgnoreCase(Logger.ROOT_LOGGER_NAME)) { 71 log4jLogger = LogManager.getRootLogger(); 72 } else { 73 log4jLogger = LogManager.getLogger(name); 74 } 75 slf4jLogger = new Log4jLoggerAdapter(log4jLogger); 76 loggerMap.put(name, slf4jLogger); 77 } 78 } 79 return slf4jLogger; 80 } 81 }