/*
* Created on Mar 7, 2007 Copyright (C) 2001-6, Anthony Harrison anh23@pitt.edu
* (jactr.org) This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public License as
* published by the Free Software Foundation; either version 2.1 of the License,
* or (at your option) any later version. This library is distributed in the
* hope that it will be useful, but WITHOUT ANY WARRANTY; without even the
* implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See
* the GNU Lesser General Public License for more details. You should have
* received a copy of the GNU Lesser General Public License along with this
* library; if not, write to the Free Software Foundation, Inc., 59 Temple
* Place, Suite 330, Boston, MA 02111-1307 USA
*/
package org.jactr.tools.tracer.listeners;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import org.jactr.core.event.IACTREvent;
import org.jactr.tools.tracer.ITraceSink;
import org.jactr.tools.tracer.transformer.IEventTransformer;
import org.jactr.tools.tracer.transformer.ITransformedEvent;
/**
* @author developer
*/
public abstract class BaseTraceListener implements ITraceListener
{
/**
* Logger definition
*/
static private final transient Log LOGGER = LogFactory
.getLog(BaseTraceListener.class);
ITraceSink _sink;
IEventTransformer _transformer;
/**
*
*/
public BaseTraceListener()
{
super();
}
/**
* @see org.jactr.tools.tracer.listeners.ITraceListener#setTraceSink(org.jactr.tools.tracer.ITraceSink)
*/
public void setTraceSink(ITraceSink sink)
{
_sink = sink;
}
protected void setEventTransformer(IEventTransformer transformer)
{
_transformer = transformer;
}
protected IEventTransformer getEventTransformer()
{
return _transformer;
}
protected void redirectEvent(IACTREvent pme)
{
if (_transformer != null)
try
{
ITransformedEvent event = _transformer.transform(pme);
if (event != null)
{
if (LOGGER.isDebugEnabled())
LOGGER.debug("transformed " + pme + " into " + event + " sinking");
sink(event);
}
}
catch (Exception e)
{
if (LOGGER.isDebugEnabled())
LOGGER.debug("Could not transform event "
+ pme.getClass().getSimpleName(), e);
}
}
protected void sink(ITransformedEvent event)
{
if (_sink != null && _sink.isOpen())
_sink.add(event);
}
}