001package ch.qos.logback.classic.model.processor; 002 003import ch.qos.logback.classic.Level; 004import ch.qos.logback.classic.Logger; 005import ch.qos.logback.classic.LoggerContext; 006import ch.qos.logback.classic.model.RootLoggerModel; 007import ch.qos.logback.core.Context; 008import ch.qos.logback.core.model.Model; 009import ch.qos.logback.core.model.processor.ModelHandlerBase; 010import ch.qos.logback.core.model.processor.ModelHandlerException; 011import ch.qos.logback.core.model.processor.ModelInterpretationContext; 012import ch.qos.logback.core.util.OptionHelper; 013 014public class RootLoggerModelHandler extends ModelHandlerBase { 015 016 Logger root; 017 boolean inError = false; 018 019 public RootLoggerModelHandler(Context context) { 020 super(context); 021 } 022 023 static public ModelHandlerBase makeInstance(Context context, ModelInterpretationContext ic) { 024 return new RootLoggerModelHandler(context); 025 } 026 027 protected Class<RootLoggerModel> getSupportedModelClass() { 028 return RootLoggerModel.class; 029 } 030 031 @Override 032 public void handle(ModelInterpretationContext mic, Model model) throws ModelHandlerException { 033 inError = false; 034 035 RootLoggerModel rootLoggerModel = (RootLoggerModel) model; 036 037 LoggerContext loggerContext = (LoggerContext) this.context; 038 root = loggerContext.getLogger(Logger.ROOT_LOGGER_NAME); 039 040 String levelStr = mic.subst(rootLoggerModel.getLevel()); 041 if (!OptionHelper.isNullOrEmpty(levelStr)) { 042 Level level = Level.toLevel(levelStr); 043 addInfo("Setting level of ROOT logger to " + level); 044 root.setLevel(level); 045 } 046 047 mic.pushObject(root); 048 } 049 050 @Override 051 public void postHandle(ModelInterpretationContext mic, Model model) { 052 if (inError) { 053 return; 054 } 055 Object o = mic.peekObject(); 056 if (o != root) { 057 addWarn("The object [" + o + "] on the top the of the stack is not the root logger"); 058 } else { 059 mic.popObject(); 060 } 061 } 062 063}