/*
* #%~
* RT Trace Viewer Plugin
* %%
* Copyright (C) 2008 - 2014 Overture
* %%
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as
* published by the Free Software Foundation, either version 3 of the
* License, or (at your option) any later version.
*
* This program 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 General Public License for more details.
*
* You should have received a copy of the GNU General Public
* License along with this program. If not, see
* <http://www.gnu.org/licenses/gpl-3.0.html>.
* #~%
*/
package org.overture.ide.plugins.rttraceviewer.event;
import org.overture.ide.plugins.rttraceviewer.data.TraceBus;
import org.overture.ide.plugins.rttraceviewer.data.TraceCPU;
import org.overture.ide.plugins.rttraceviewer.data.TraceData;
import org.overture.ide.plugins.rttraceviewer.data.TraceObject;
import org.overture.ide.plugins.rttraceviewer.data.TraceOperation;
import org.overture.ide.plugins.rttraceviewer.data.TraceThread;
import org.overture.ide.plugins.rttraceviewer.data.UnexpectedEventTypeException;
import org.overture.ide.plugins.rttraceviewer.view.GenericTabItem;
import org.overture.interpreter.messages.rtlog.nextgen.INextGenEvent;
import org.overture.interpreter.messages.rtlog.nextgen.NextGenBusMessageEvent;
public class BusMessageEventHandler extends EventHandler {
public BusMessageEventHandler(TraceData data) {
super(data);
}
@Override
protected void handle(INextGenEvent event, GenericTabItem tab) {
NextGenBusMessageEvent bEvent = null;
if(event instanceof NextGenBusMessageEvent)
bEvent = (NextGenBusMessageEvent)event;
else
throw new IllegalArgumentException("BusMessageEventHandler expected event of type: " + NextGenBusMessageEvent.class.getName());
TraceCPU fromCpu = data.getCPU(new Long(bEvent.message.fromCpu.id));
TraceCPU toCpu = data.getCPU(new Long(bEvent.message.toCpu.id));
TraceBus bus = data.getBUS(new Long(bEvent.message.bus.id));
TraceObject fromObject = data.getObject(new Long(bEvent.message.object.id));
TraceOperation op = data.getOperation(bEvent.message.operation.classDef.name + bEvent.message.operation.name);
TraceThread currentThread = null;
Long currentThreadId = toCpu.getCurrentThread();
if(currentThreadId != null)
{
currentThread = data.getThread(currentThreadId);
}
//TODO: MVQ: Review if all objects are required in all draw methods
switch(bEvent.type)
{
case REQUEST:
//Determine from object by thread. Object may be null on some threads (INIT, MAIN etc)
if(bEvent.message.callerThread.object != null) {
fromObject = data.getObject(new Long(bEvent.message.callerThread.object.id));
} else {
TraceThread fromThread = data.getThread(bEvent.message.callerThread.id);
fromObject = fromThread.getCurrentObject();
}
eventViewer.drawMessageRequest(tab, fromCpu, fromObject, bus, op);
break;
case ACTIVATE:
eventViewer.drawMessageActivated(tab, fromCpu, fromObject, bus, op);
break;
case COMPLETED:
if(bEvent.message.receiverThread != null)
{
TraceThread receiverThread = data.getThread(bEvent.message.receiverThread.id);
fromObject = receiverThread.getCurrentObject();
eventViewer.drawMessageCompleted(tab, toCpu, currentThread, bus, op, fromObject);
//If this is a reply to an earlier request then unblock the thread which did the request
receiverThread.setStatus(false);
}
else
{
eventViewer.drawMessageCompleted(tab, toCpu, currentThread, bus, op, fromObject);
}
break;
case REPLY_REQUEST:
throw new UnexpectedEventTypeException("Problem in BusMessageEventHandler. REPLY_REQYEST events should be handled in " + BusMessageReplyEventHandler.class.getName());
default:
throw new UnexpectedEventTypeException("Problem in BusMessageEventHandler. Unexpected bus message event type.");
}
return;
}
}