blob: 1e19d1d4149b9d9bc70fd2f786850cd4970aaf07 [file] [log] [blame]
/*******************************************************************************
* Copyright (c) 2009, 2014 Ericsson
*
* All rights reserved. This program and the accompanying materials are
* made available under the terms of the Eclipse Public License 2.0 which
* accompanies this distribution, and is available at
* https://www.eclipse.org/legal/epl-2.0/
*
* SPDX-License-Identifier: EPL-2.0
*
* Contributors:
* William Bourque - Initial API and implementation
* Yuriy Vashchuk - Heritage correction.
* Francois Chouinard - Cleanup and refactoring
* Francois Chouinard - Moved from LTTng to TMF
* Simon Delisle - Added a new parameter to the constructor
* Xavier Raynaud - Support multi-trace coloring
*******************************************************************************/
package org.eclipse.tracecompass.tmf.ui.views.histogram;
import org.eclipse.tracecompass.tmf.core.event.ITmfEvent;
import org.eclipse.tracecompass.tmf.core.event.ITmfLostEvent;
import org.eclipse.tracecompass.tmf.core.request.ITmfEventRequest;
import org.eclipse.tracecompass.tmf.core.request.TmfEventRequest;
import org.eclipse.tracecompass.tmf.core.timestamp.TmfTimeRange;
/**
* Class to request events for given time range from a trace to fill a
* HistogramDataModel and HistogramView.
*
* @version 1.0
* @author Francois Chouinard
* <p>
*/
public class HistogramRequest extends TmfEventRequest {
// ------------------------------------------------------------------------
// Attributes
// ------------------------------------------------------------------------
/**
* The histogram data model to fill.
*/
protected final HistogramDataModel fHistogram;
private final boolean fFullRange;
// ------------------------------------------------------------------------
// Constructor
// ------------------------------------------------------------------------
/**
* Constructor
*
* @param histogram
* The histogram data model
* @param range
* The time range to request data
* @param rank
* The index of the first event to retrieve
* @param nbEvents
* The number of events requested
* @param blockSize
* The number of events per block
* @param execType
* The requested execution priority
* @param fullRange
* Full range or time range for histogram request
*/
public HistogramRequest(HistogramDataModel histogram, TmfTimeRange range,
int rank, int nbEvents, int blockSize,
ITmfEventRequest.ExecutionType execType, boolean fullRange) {
super(ITmfEvent.class, range, rank, nbEvents, execType);
fHistogram = histogram;
fFullRange = fullRange;
}
// ------------------------------------------------------------------------
// TmfEventRequest
// ------------------------------------------------------------------------
/**
* Handle the event from the trace by updating the histogram data model.
*
* @param event
* a event from the trace
* @see org.eclipse.tracecompass.tmf.core.request.TmfEventRequest#handleData(org.eclipse.tracecompass.tmf.core.event.ITmfEvent)
*/
@Override
public void handleData(ITmfEvent event) {
super.handleData(event);
synchronized (fHistogram) {
if (!isCancelled()) {
if (event instanceof ITmfLostEvent) {
ITmfLostEvent lostEvents = (ITmfLostEvent) event;
/* clear the old data when it is a new request */
fHistogram.countLostEvent(lostEvents.getTimeRange(), lostEvents.getNbLostEvents(), fFullRange);
} else { /* handle lost event */
long timestamp = event.getTimestamp().toNanos();
fHistogram.countEvent(getNbRead(), timestamp, event.getTrace());
}
}
}
}
/**
* Complete the request. It also notifies the histogram model about the
* completion.
*
* @see org.eclipse.tracecompass.tmf.core.request.TmfEventRequest#handleCompleted()
*/
@Override
public void handleCompleted() {
fHistogram.complete();
super.handleCompleted();
}
}