queue.push(command);
}
public void run(MarkupWriter writer)
{
RenderCommand command = null;
boolean traceEnabled = logger.isTraceEnabled(TapestryMarkers.RENDER_COMMANDS);
long startNanos = System.nanoTime();
int commandCount = 0;
int maxDepth = 0;
// Seems to make sense to use one try/finally around the whole process, rather than
// around each call to render() since the end result (in a failure scenario) is the same.
try
{
while (!queue.isEmpty())
{
maxDepth = Math.max(maxDepth, queue.getDepth());
command = queue.pop();
commandCount++;
if (traceEnabled) logger.trace(TapestryMarkers.RENDER_COMMANDS, "Executing: {}", command);
command.render(writer, this);
}
}
catch (RuntimeException ex)
{
// This will likely leave the page in a dirty state, and it will not go back into the