org.apache.juli.logging.ch.qos.logback.core.joran.action.PropertyAction Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of tomcat85-slf4j-logback Show documentation
Show all versions of tomcat85-slf4j-logback Show documentation
Tomcat85 Slf4j Logback Integration
/**
* Logback: the reliable, generic, fast and flexible logging framework.
* Copyright (C) 1999-2015, QOS.ch. All rights reserved.
*
* This program and the accompanying materials are dual-licensed under
* either the terms of the Eclipse Public License v1.0 as published by
* the Eclipse Foundation
*
* or (per the licensee's choosing)
*
* under the terms of the GNU Lesser General Public License version 2.1
* as published by the Free Software Foundation.
*/
package org.apache.juli.logging.ch.qos.logback.core.joran.action;
import org.xml.sax.Attributes;
import org.apache.juli.logging.ch.qos.logback.core.joran.spi.SaxEventInterpretationContext;
import org.apache.juli.logging.ch.qos.logback.core.model.Model;
import org.apache.juli.logging.ch.qos.logback.core.model.PropertyModel;
/**
* This class serves to build a model for properties which are to the ANT
* <property> task which add/set properties of a given object.
*
* @author Ceki Gülcü
*/
public class PropertyAction extends BaseModelAction {
static final String RESOURCE_ATTRIBUTE = "resource";
@Override
protected boolean validPreconditions(SaxEventInterpretationContext interpretationContext, String localName,
Attributes attributes) {
if ("substitutionProperty".equals(localName)) {
addWarn("[substitutionProperty] element has been deprecated. Please use the [variable] element instead.");
}
return true;
}
@Override
protected Model buildCurrentModel(SaxEventInterpretationContext interpretationContext, String name,
Attributes attributes) {
PropertyModel propertyModel = new PropertyModel();
propertyModel.setName(attributes.getValue(NAME_ATTRIBUTE));
propertyModel.setValue(attributes.getValue(VALUE_ATTRIBUTE));
propertyModel.setScopeStr(attributes.getValue(SCOPE_ATTRIBUTE));
propertyModel.setFile(attributes.getValue(FILE_ATTRIBUTE));
propertyModel.setResource(attributes.getValue(RESOURCE_ATTRIBUTE));
return propertyModel;
}
}