org.apache.juli.logging.ch.qos.logback.core.joran.spi.EventPlayer 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.spi;
import java.util.ArrayList;
import java.util.List;
import org.apache.juli.logging.ch.qos.logback.core.joran.event.BodyEvent;
import org.apache.juli.logging.ch.qos.logback.core.joran.event.EndEvent;
import org.apache.juli.logging.ch.qos.logback.core.joran.event.SaxEvent;
import org.apache.juli.logging.ch.qos.logback.core.joran.event.StartEvent;
public class EventPlayer {
final Interpreter interpreter;
List eventList;
int currentIndex;
public EventPlayer(Interpreter interpreter) {
this.interpreter = interpreter;
}
/**
* Return a copy of the current event list in the player.
* @return
* @since 0.9.20
*/
public List getCopyOfPlayerEventList() {
return new ArrayList(eventList);
}
public void play(List aSaxEventList) {
eventList = aSaxEventList;
SaxEvent se;
for (currentIndex = 0; currentIndex < eventList.size(); currentIndex++) {
se = eventList.get(currentIndex);
if (se instanceof StartEvent) {
interpreter.startElement((StartEvent) se);
// invoke fireInPlay after startElement processing
interpreter.getInterpretationContext().fireInPlay(se);
}
if (se instanceof BodyEvent) {
// invoke fireInPlay before characters processing
interpreter.getInterpretationContext().fireInPlay(se);
interpreter.characters((BodyEvent) se);
}
if (se instanceof EndEvent) {
// invoke fireInPlay before endElement processing
interpreter.getInterpretationContext().fireInPlay(se);
interpreter.endElement((EndEvent) se);
}
}
}
public void addEventsDynamically(List eventList, int offset) {
this.eventList.addAll(currentIndex + offset, eventList);
}
}