import org.eclipse.jface.viewers.ISelection;
import org.eclipse.jface.viewers.ISelectionProvider;
import org.eclipse.jface.viewers.TreeSelection;
+import org.eclipse.linuxtools.internal.tmf.ui.Activator;
import org.eclipse.linuxtools.tmf.core.TmfCommonConstants;
import org.eclipse.linuxtools.tmf.core.event.ITmfEvent;
import org.eclipse.linuxtools.tmf.core.exceptions.TmfTraceException;
import org.eclipse.linuxtools.tmf.ui.editors.TmfEventsEditor;
import org.eclipse.linuxtools.tmf.ui.project.model.TmfExperimentElement;
import org.eclipse.linuxtools.tmf.ui.project.model.TmfTraceElement;
+import org.eclipse.swt.widgets.Display;
import org.eclipse.swt.widgets.MessageBox;
import org.eclipse.ui.IEditorInput;
import org.eclipse.ui.IEditorPart;
// Execution
// ------------------------------------------------------------------------
- @SuppressWarnings({ "rawtypes", "unchecked" })
@Override
public Object execute(final ExecutionEvent event) throws ExecutionException {
return false;
}
- try {
- final IFile bookmarksFile = fExperiment.getProject().getExperimentsFolder().getResource().getFile(BOOKMARKS_HIDDEN_FILE);
- if (!bookmarksFile.exists()) {
- final InputStream source = new ByteArrayInputStream(new byte[0]);
- bookmarksFile.create(source, true, null);
- }
- bookmarksFile.setHidden(true);
+ final TmfExperimentElement experimentElement = fExperiment;
+
+ Thread thread = new Thread() {
+ @Override
+ public void run() {
+
+ final IFile file;
- final IFile file = fExperiment.getResource().getFile(fExperiment.getName() + '_');
- if (!file.exists()) {
- file.createLink(bookmarksFile.getLocation(), IResource.REPLACE, null);
- }
- file.setHidden(true);
- file.setPersistentProperty(TmfCommonConstants.TRACETYPE, TmfExperiment.class.getCanonicalName());
-
- // Instantiate the experiment's traces
- final List<TmfTraceElement> traceEntries = fExperiment.getTraces();
- final int nbTraces = traceEntries.size();
- int cacheSize = Integer.MAX_VALUE;
- String commonEditorId = null;
- final ITmfTrace[] traces = new ITmfTrace[nbTraces];
- for (int i = 0; i < nbTraces; i++) {
- TmfTraceElement element = traceEntries.get(i);
-
- // Since trace is under an experiment, use the original trace from the traces folder
- element = element.getElementUnderTraceFolder();
-
- final ITmfTrace trace = element.instantiateTrace();
- final ITmfEvent traceEvent = element.instantiateEvent();
- if ((trace == null) || (traceEvent == null)) {
- displayErrorMsg(Messages.OpenExperimentHandler_NoTraceType);
- for (int j = 0; j < i; j++) {
- traces[j].dispose();
- }
- return null;
- }
try {
- trace.initTrace(element.getResource(), element.getLocation().getPath(), traceEvent.getClass());
- } catch (final TmfTraceException e) {
- displayErrorMsg(""); //$NON-NLS-1$
- }
- cacheSize = Math.min(cacheSize, trace.getCacheSize());
-
- // If all traces use the same editorId, use it, otherwise use the default
- final String editorId = element.getEditorId();
- if (commonEditorId == null) {
- commonEditorId = (editorId != null) ? editorId : TmfEventsEditor.ID;
- } else if (!commonEditorId.equals(editorId)) {
- commonEditorId = TmfEventsEditor.ID;
- }
- traces[i] = trace;
- }
+ final IFile bookmarksFile = experimentElement.getProject().getExperimentsFolder().getResource().getFile(BOOKMARKS_HIDDEN_FILE);
+ if (!bookmarksFile.exists()) {
+ final InputStream source = new ByteArrayInputStream(new byte[0]);
+ bookmarksFile.create(source, true, null);
+ }
+ bookmarksFile.setHidden(true);
+
+ file = experimentElement.getResource().getFile(experimentElement.getName() + '_');
+ if (!file.exists()) {
+ file.createLink(bookmarksFile.getLocation(), IResource.REPLACE, null);
+ }
+ file.setHidden(true);
+ file.setPersistentProperty(TmfCommonConstants.TRACETYPE, TmfExperiment.class.getCanonicalName());
- // Create the experiment
- TmfExperiment experiment = new TmfExperiment(ITmfEvent.class, fExperiment.getName(), traces, cacheSize);
- experiment.setBookmarksFile(file);
+ } catch (final CoreException e) {
+ Activator.getDefault().logError("Error opening experiment " + experimentElement.getName(), e); //$NON-NLS-1$
+ displayErrorMsg(Messages.OpenExperimentHandler_Error + "\n\n" + e.getMessage()); //$NON-NLS-1$
+ return;
+ }
- final IEditorInput editorInput = new TmfEditorInput(file, experiment);
- final IWorkbench wb = PlatformUI.getWorkbench();
- final IWorkbenchPage activePage = wb.getActiveWorkbenchWindow().getActivePage();
+ // Instantiate the experiment's traces
+ final List<TmfTraceElement> traceEntries = experimentElement.getTraces();
+ final int nbTraces = traceEntries.size();
+ int cacheSize = Integer.MAX_VALUE;
+ String commonEditorId = null;
+ final ITmfTrace[] traces = new ITmfTrace[nbTraces];
+ for (int i = 0; i < nbTraces; i++) {
+ TmfTraceElement element = traceEntries.get(i);
+
+ // Since trace is under an experiment, use the original trace from the traces folder
+ element = element.getElementUnderTraceFolder();
+
+ final ITmfTrace trace = element.instantiateTrace();
+ final ITmfEvent traceEvent = element.instantiateEvent();
+ if ((trace == null) || (traceEvent == null)) {
+ displayErrorMsg(Messages.OpenExperimentHandler_NoTraceType);
+ for (int j = 0; j < i; j++) {
+ traces[j].dispose();
+ }
+ if (trace != null) {
+ trace.dispose();
+ }
+ return;
+ }
+ try {
+ trace.initTrace(element.getResource(), element.getLocation().getPath(), traceEvent.getClass());
+ } catch (final TmfTraceException e) {
+ displayErrorMsg(Messages.OpenTraceHandler_InitError + "\n\n" + e); //$NON-NLS-1$
+ for (int j = 0; j < i; j++) {
+ traces[j].dispose();
+ }
+ trace.dispose();
+ return;
+ }
+ cacheSize = Math.min(cacheSize, trace.getCacheSize());
+
+ // If all traces use the same editorId, use it, otherwise use the default
+ final String editorId = element.getEditorId();
+ if (commonEditorId == null) {
+ commonEditorId = (editorId != null) ? editorId : TmfEventsEditor.ID;
+ } else if (!commonEditorId.equals(editorId)) {
+ commonEditorId = TmfEventsEditor.ID;
+ }
+ traces[i] = trace;
+ }
- final IEditorPart editor = activePage.findEditor(new FileEditorInput(file));
- if ((editor != null) && (editor instanceof IReusableEditor)) {
- activePage.reuseEditor((IReusableEditor) editor, editorInput);
- activePage.activate(editor);
- } else {
- activePage.openEditor(editorInput, commonEditorId);
+ // Create the experiment
+ final TmfExperiment experiment = new TmfExperiment(ITmfEvent.class, experimentElement.getName(), traces, cacheSize);
+ experiment.setBookmarksFile(file);
+
+ final String finalCommonEditorId = commonEditorId;
+ Display.getDefault().asyncExec(new Runnable() {
+ @Override
+ public void run() {
+ try {
+ final IEditorInput editorInput = new TmfEditorInput(file, experiment);
+ final IWorkbench wb = PlatformUI.getWorkbench();
+ final IWorkbenchPage activePage = wb.getActiveWorkbenchWindow().getActivePage();
+
+ final IEditorPart editor = activePage.findEditor(new FileEditorInput(file));
+ if ((editor != null) && (editor instanceof IReusableEditor)) {
+ activePage.reuseEditor((IReusableEditor) editor, editorInput);
+ activePage.activate(editor);
+ } else {
+ activePage.openEditor(editorInput, finalCommonEditorId);
+ }
+ IDE.setDefaultEditor(file, finalCommonEditorId);
+ // editor should dispose the experiment on close
+ } catch (final CoreException e) {
+ Activator.getDefault().logError("Error opening experiment " + experimentElement.getName(), e); //$NON-NLS-1$
+ displayErrorMsg(Messages.OpenExperimentHandler_Error + "\n\n" + e.getMessage()); //$NON-NLS-1$
+ experiment.dispose();
+ return;
+ }
+ }
+ });
}
- IDE.setDefaultEditor(file, commonEditorId);
- // editor should dispose the experiment on close
- } catch (final CoreException e) {
- displayErrorMsg(e.getMessage());
- }
+ };
+
+ thread.start();
return null;
}
private static void displayErrorMsg(final String errorMsg) {
- final MessageBox mb = new MessageBox(PlatformUI.getWorkbench().getActiveWorkbenchWindow().getShell());
- mb.setText(Messages.OpenExperimentHandler_Title);
- mb.setMessage(errorMsg);
- mb.open();
+ Display.getDefault().asyncExec(new Runnable() {
+ @Override
+ public void run() {
+ final MessageBox mb = new MessageBox(PlatformUI.getWorkbench().getActiveWorkbenchWindow().getShell());
+ mb.setText(Messages.OpenExperimentHandler_Title);
+ mb.setMessage(errorMsg);
+ mb.open();
+ }
+ });
}
-
}
import org.eclipse.linuxtools.tmf.ui.editors.TmfEditorInput;
import org.eclipse.linuxtools.tmf.ui.editors.TmfEventsEditor;
import org.eclipse.linuxtools.tmf.ui.project.model.TmfTraceElement;
+import org.eclipse.swt.widgets.Display;
import org.eclipse.swt.widgets.MessageBox;
import org.eclipse.ui.IEditorInput;
import org.eclipse.ui.IEditorPart;
}
// If trace is under an experiment, use the original trace from the traces folder
- fTrace = fTrace.getElementUnderTraceFolder();
-
- final ITmfTrace trace = fTrace.instantiateTrace();
- final ITmfEvent traceEvent = fTrace.instantiateEvent();
- if ((trace == null) || (traceEvent == null)) {
- displayErrorMsg(Messages.OpenTraceHandler_NoTraceType);
- return null;
- }
-
- // Get the editor_id from the extension point
- String traceEditorId = fTrace.getEditorId();
- final String editorId = (traceEditorId != null) ? traceEditorId : TmfEventsEditor.ID;
-
- try {
- trace.initTrace(fTrace.getResource(), fTrace.getLocation().getPath(), traceEvent.getClass());
- } catch (final TmfTraceException e) {
- displayErrorMsg(Messages.OpenTraceHandler_NoTrace + "\n\n" + e); //$NON-NLS-1$
- return null;
- }
-
- final IResource resource = fTrace.getResource();
- IFile file = null;
- if (resource instanceof IFile) {
- file = (IFile) resource;
- } else if (resource instanceof IFolder) {
- try {
- final IFile bookmarksFile = fTrace.getProject().getTracesFolder().getResource().getFile(BOOKMARKS_HIDDEN_FILE);
- if (!bookmarksFile.exists()) {
- final InputStream source = new ByteArrayInputStream(new byte[0]);
- bookmarksFile.create(source, true, null);
+ final TmfTraceElement traceElement = fTrace.getElementUnderTraceFolder();
+
+ Thread thread = new Thread() {
+ @Override
+ public void run() {
+
+ final ITmfTrace trace = traceElement.instantiateTrace();
+ final ITmfEvent traceEvent = traceElement.instantiateEvent();
+ if ((trace == null) || (traceEvent == null)) {
+ displayErrorMsg(Messages.OpenTraceHandler_NoTraceType);
+ if (trace != null) {
+ trace.dispose();
+ }
+ return;
}
- bookmarksFile.setHidden(true);
- final IFolder folder = (IFolder) resource;
- file = folder.getFile(fTrace.getName() + '_');
- if (!file.exists()) {
- file.createLink(bookmarksFile.getLocation(), IResource.REPLACE, null);
+ // Get the editor_id from the extension point
+ String traceEditorId = traceElement.getEditorId();
+ final String editorId = (traceEditorId != null) ? traceEditorId : TmfEventsEditor.ID;
+
+ try {
+ trace.initTrace(traceElement.getResource(), traceElement.getLocation().getPath(), traceEvent.getClass());
+ } catch (final TmfTraceException e) {
+ displayErrorMsg(Messages.OpenTraceHandler_InitError + "\n\n" + e); //$NON-NLS-1$
+ trace.dispose();
+ return;
}
- file.setHidden(true);
- file.setPersistentProperty(TmfCommonConstants.TRACETYPE, TmfTrace.class.getCanonicalName());
- IDE.setDefaultEditor(file, editorId);
- } catch (final CoreException e) {
- Activator.getDefault().logError("Error opening trace " + fTrace.getName(), e); //$NON-NLS-1$
- }
- }
- try {
- final IEditorInput editorInput = new TmfEditorInput(file, trace);
- final IWorkbench wb = PlatformUI.getWorkbench();
- final IWorkbenchPage activePage = wb.getActiveWorkbenchWindow().getActivePage();
-
- final IEditorPart editor = activePage.findEditor(new FileEditorInput(file));
- if ((editor != null) && (editor instanceof IReusableEditor)) {
- activePage.reuseEditor((IReusableEditor) editor, editorInput);
- activePage.activate(editor);
- } else {
- activePage.openEditor(editorInput, editorId);
+ final IResource resource = traceElement.getResource();
+ IFile file = null;
if (resource instanceof IFile) {
- IDE.setDefaultEditor((IFile) resource, editorId);
+ file = (IFile) resource;
+ } else if (resource instanceof IFolder) {
+ try {
+ final IFile bookmarksFile = traceElement.getProject().getTracesFolder().getResource().getFile(BOOKMARKS_HIDDEN_FILE);
+ if (!bookmarksFile.exists()) {
+ final InputStream source = new ByteArrayInputStream(new byte[0]);
+ bookmarksFile.create(source, true, null);
+ }
+ bookmarksFile.setHidden(true);
+
+ final IFolder folder = (IFolder) resource;
+ file = folder.getFile(traceElement.getName() + '_');
+ if (!file.exists()) {
+ file.createLink(bookmarksFile.getLocation(), IResource.REPLACE, null);
+ }
+ file.setHidden(true);
+ file.setPersistentProperty(TmfCommonConstants.TRACETYPE, TmfTrace.class.getCanonicalName());
+ IDE.setDefaultEditor(file, editorId);
+ // editor should dispose the experiment on close
+ } catch (final CoreException e) {
+ Activator.getDefault().logError("Error opening trace " + traceElement.getName(), e); //$NON-NLS-1$
+ displayErrorMsg(Messages.OpenTraceHandler_Error + "\n\n" + e.getMessage()); //$NON-NLS-1$
+ trace.dispose();
+ return;
+ }
}
+
+ final IFile editorFile = file;
+ Display.getDefault().asyncExec(new Runnable() {
+ @Override
+ public void run() {
+ try {
+ final IEditorInput editorInput = new TmfEditorInput(editorFile, trace);
+ final IWorkbench wb = PlatformUI.getWorkbench();
+ final IWorkbenchPage activePage = wb.getActiveWorkbenchWindow().getActivePage();
+
+ final IEditorPart editor = activePage.findEditor(new FileEditorInput(editorFile));
+ if ((editor != null) && (editor instanceof IReusableEditor)) {
+ activePage.reuseEditor((IReusableEditor) editor, editorInput);
+ activePage.activate(editor);
+ } else {
+ activePage.openEditor(editorInput, editorId);
+ if (resource instanceof IFile) {
+ IDE.setDefaultEditor((IFile) resource, editorId);
+ }
+ }
+ } catch (final PartInitException e) {
+ displayErrorMsg(Messages.OpenTraceHandler_Error + "\n\n" + e.getMessage()); //$NON-NLS-1$
+ Activator.getDefault().logError("Error opening trace " + traceElement.getName(), e); //$NON-NLS-1$
+ trace.dispose();
+ }
+ }
+ });
+
}
- } catch (final PartInitException e) {
- Activator.getDefault().logError("Error opening trace " + fTrace.getName(), e); //$NON-NLS-1$
- }
+ };
+
+ thread.start();
return null;
}
private static void displayErrorMsg(final String errorMsg) {
- final MessageBox mb = new MessageBox(PlatformUI.getWorkbench().getActiveWorkbenchWindow().getShell());
- mb.setText(Messages.OpenTraceHandler_Title);
- mb.setMessage(errorMsg);
- mb.open();
+ Display.getDefault().asyncExec(new Runnable() {
+ @Override
+ public void run() {
+ final MessageBox mb = new MessageBox(PlatformUI.getWorkbench().getActiveWorkbenchWindow().getShell());
+ mb.setText(Messages.OpenTraceHandler_Title);
+ mb.setMessage(errorMsg);
+ mb.open();
+ }
+ });
}
}