/*
* Created on Feb 22, 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.transformer.declarative;
import org.antlr.runtime.tree.CommonTree;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import org.jactr.core.event.IACTREvent;
import org.jactr.core.module.declarative.event.DeclarativeModuleEvent;
import org.jactr.io.resolver.ASTResolver;
import org.jactr.tools.tracer.transformer.IEventTransformer;
import org.jactr.tools.tracer.transformer.ITransformedEvent;
/**
* @author developer
*/
public class DeclarativeModuleEventTransformer implements IEventTransformer
{
/**
* logger definition
*/
static private final Log LOGGER = LogFactory
.getLog(DeclarativeModuleEventTransformer.class);
/**
* @see org.jactr.tools.tracer.transformer.IEventTransformer#transform(IACTREvent)
*/
public ITransformedEvent transform(IACTREvent actrEvent)
{
DeclarativeModuleEvent event = (DeclarativeModuleEvent) actrEvent;
String source = event.getSource().getName();
long system = event.getSystemTime();
double time = event.getSimulationTime();
DeclarativeModuleEvent.Type type = event.getType();
CommonTree payload = null;
try
{
switch (type)
{
case CHUNK_CREATED:
case CHUNK_ADDED:
payload = ASTResolver.toAST(event.getChunk(), false);
break;
case CHUNK_TYPE_CREATED:
case CHUNK_TYPE_ADDED:
payload = ASTResolver.toAST(event.getChunkType(), false);
break;
default:
if (LOGGER.isDebugEnabled())
LOGGER.debug("No payload transform available for " + type);
}
return new TransformedDeclarativeModuleEvent(source, system, time, type,
payload);
}
catch (Exception e)
{
LOGGER.debug("Could not transform event ", e);
}
return null;
}
}