001package ch.qos.logback.classic.model.processor; 002 003import static ch.qos.logback.core.joran.JoranConstants.NULL; 004 005import ch.qos.logback.classic.Level; 006import ch.qos.logback.classic.Logger; 007import ch.qos.logback.classic.LoggerContext; 008import ch.qos.logback.classic.model.LoggerModel; 009import ch.qos.logback.core.Context; 010import ch.qos.logback.core.joran.JoranConstants; 011import ch.qos.logback.core.model.Model; 012import ch.qos.logback.core.model.processor.ModelHandlerBase; 013import ch.qos.logback.core.model.processor.ModelHandlerException; 014import ch.qos.logback.core.model.processor.ModelInterpretationContext; 015import ch.qos.logback.core.spi.ErrorCodes; 016import ch.qos.logback.core.util.OptionHelper; 017 018public class LoggerModelHandler extends ModelHandlerBase { 019 020 Logger logger; 021 boolean inError = false; 022 023 public LoggerModelHandler(Context context) { 024 super(context); 025 } 026 027 static public ModelHandlerBase makeInstance(Context context, ModelInterpretationContext mic) { 028 return new LoggerModelHandler(context); 029 } 030 031 protected Class<LoggerModel> getSupportedModelClass() { 032 return LoggerModel.class; 033 } 034 035 @Override 036 public void handle(ModelInterpretationContext mic, Model model) throws ModelHandlerException { 037 inError = false; 038 039 LoggerModel loggerModel = (LoggerModel) model; 040 041 String finalLoggerName = mic.subst(loggerModel.getName()); 042 043 LoggerContext loggerContext = (LoggerContext) this.context; 044 045 logger = loggerContext.getLogger(finalLoggerName); 046 047 String levelStr = mic.subst(loggerModel.getLevel()); 048 if (!OptionHelper.isNullOrEmpty(levelStr)) { 049 if (JoranConstants.INHERITED.equalsIgnoreCase(levelStr) || NULL.equalsIgnoreCase(levelStr)) { 050 if(Logger.ROOT_LOGGER_NAME.equalsIgnoreCase(finalLoggerName)) { 051 addError(ErrorCodes.ROOT_LEVEL_CANNOT_BE_SET_TO_NULL); 052 } else { 053 addInfo("Setting level of logger [" + finalLoggerName + "] to null, i.e. INHERITED"); 054 logger.setLevel(null); 055 } 056 } else { 057 Level level = Level.toLevel(levelStr); 058 addInfo("Setting level of logger [" + finalLoggerName + "] to " + level); 059 logger.setLevel(level); 060 } 061 } 062 063 String additivityStr = mic.subst(loggerModel.getAdditivity()); 064 if (!OptionHelper.isNullOrEmpty(additivityStr)) { 065 boolean additive = OptionHelper.toBoolean(additivityStr, true); 066 addInfo("Setting additivity of logger [" + finalLoggerName + "] to " + additive); 067 logger.setAdditive(additive); 068 } 069 070 mic.pushObject(logger); 071 } 072 073 @Override 074 public void postHandle(ModelInterpretationContext mic, Model model) { 075 if (inError) { 076 return; 077 } 078 Object o = mic.peekObject(); 079 if (o != logger) { 080 LoggerModel loggerModel = (LoggerModel) model; 081 addWarn("The object [" + o + "] on the top the of the stack is not the expected logger named " 082 + loggerModel.getName()); 083 } else { 084 mic.popObject(); 085 } 086 087 } 088 089}