blob: b22d68f5192e7f9e909e901a0e7458995700b75b [file] [log] [blame]
/**********************************************************************
* Copyright (c) 2012, 2015 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:
* Bernd Hufmann - Initial API and implementation
* Bernd Hufmann - Updated for support of LTTng Tools 2.1
**********************************************************************/
package org.eclipse.tracecompass.internal.lttng2.control.ui.views.handlers;
import java.util.Iterator;
import java.util.List;
import org.eclipse.core.commands.ExecutionException;
import org.eclipse.core.runtime.IProgressMonitor;
import org.eclipse.jface.viewers.ISelection;
import org.eclipse.jface.viewers.StructuredSelection;
import org.eclipse.tracecompass.common.core.NonNullUtils;
import org.eclipse.tracecompass.internal.lttng2.control.core.model.TraceDomainType;
import org.eclipse.tracecompass.internal.lttng2.control.core.model.ITraceLogLevel;
import org.eclipse.tracecompass.internal.lttng2.control.core.model.LogLevelType;
import org.eclipse.tracecompass.internal.lttng2.control.core.model.TraceSessionState;
import org.eclipse.tracecompass.internal.lttng2.control.ui.views.ControlView;
import org.eclipse.tracecompass.internal.lttng2.control.ui.views.model.impl.TraceDomainComponent;
import org.eclipse.tracecompass.internal.lttng2.control.ui.views.model.impl.TraceSessionComponent;
import org.eclipse.ui.IWorkbenchPage;
/**
* <p>
* Command handler implementation to enable events for a known session and default channel 'channel0'
* (which will be created if doesn't exist).
* </p>
*
* @author Bernd Hufmann
*/
public class EnableEventOnSessionHandler extends BaseEnableEventHandler {
// ------------------------------------------------------------------------
// Attributes
// ------------------------------------------------------------------------
//-------------------------------------------------------------------------
// Operations
// ------------------------------------------------------------------------
@Override
public void enableEvents(CommandParameter param, List<String> eventNames, TraceDomainType domain, String filterExpression, List<String> excludedEvents, IProgressMonitor monitor) throws ExecutionException {
param.getSession().enableEvents(eventNames, domain, filterExpression, excludedEvents, monitor);
}
@Override
public void enableSyscalls(CommandParameter param, List<String> syscallNames, IProgressMonitor monitor) throws ExecutionException {
param.getSession().enableSyscalls(syscallNames, monitor);
}
@Override
public void enableProbe(CommandParameter param, String eventName, boolean isFunction, String probe, IProgressMonitor monitor) throws ExecutionException {
param.getSession().enableProbe(eventName, isFunction, probe, monitor);
}
@Override
public void enableLogLevel(CommandParameter param, List<String> eventNames, LogLevelType logLevelType, ITraceLogLevel level, String filterExpression, TraceDomainType domain, IProgressMonitor monitor) throws ExecutionException {
param.getSession().enableLogLevel(eventNames, logLevelType, level, filterExpression, domain, monitor);
}
@Override
public TraceDomainComponent getDomain(CommandParameter param) {
return null;
}
@Override
public boolean isEnabled() {
// Get workbench page for the Control View
IWorkbenchPage page = getWorkbenchPage();
if (page == null) {
return false;
}
TraceSessionComponent session = null;
// Check if one session is selected
ISelection selection = page.getSelection(ControlView.ID);
if (selection instanceof StructuredSelection) {
StructuredSelection structered = ((StructuredSelection) selection);
for (Iterator<?> iterator = structered.iterator(); iterator.hasNext();) {
Object element = iterator.next();
if (element instanceof TraceSessionComponent) {
// Add only if corresponding TraceSessionComponents is inactive and not destroyed
TraceSessionComponent tmpSession = (TraceSessionComponent) element;
if(tmpSession.getSessionState() == TraceSessionState.INACTIVE && !tmpSession.isDestroyed()) {
session = tmpSession;
}
}
}
}
boolean isEnabled = (session != null);
fLock.lock();
try {
fParam = null;
if(isEnabled) {
fParam = new CommandParameter(NonNullUtils.checkNotNull(session));
}
} finally {
fLock.unlock();
}
return isEnabled;
}
}