/******************************************************************************* * Copyright (c) 2007 committers of openArchitectureWare and others. * All rights reserved. This program and the accompanying materials * are made available under the terms of the Eclipse Public License v1.0 * which accompanies this distribution, and is available at * http://www.eclipse.org/legal/epl-v10.html * * Contributors: * committers of openArchitectureWare - initial API and implementation *******************************************************************************/ package org.eclipse.xtend.shared.ui.editor; import org.eclipse.core.resources.IResource; import org.eclipse.core.runtime.CoreException; import org.eclipse.debug.core.DebugPlugin; import org.eclipse.debug.core.IBreakpointManager; import org.eclipse.debug.core.model.IBreakpoint; import org.eclipse.emf.mwe.ui.debug.model.MWEBreakpoint; import org.eclipse.emf.mwe.ui.debug.processing.PluginAdapter; import org.eclipse.emf.mwe.ui.debug.processing.PluginExtensionManager; import org.eclipse.jface.action.Action; import org.eclipse.ui.editors.text.TextEditor; import org.eclipse.xtend.shared.ui.Messages; /** * Toggle breakpoint action that can be used both at vertical ruler and editor context menu. * */ public class ToggleBreakpointAction extends Action { private final TextEditor editor; private final BreakpointActionGroup group; public ToggleBreakpointAction(final TextEditor editor, final BreakpointActionGroup group) { this.editor = editor; this.group = group; setText(Messages.ToggleBreakpointAction_ToggleAction); setToolTipText(Messages.ToggleBreakpointAction_Description); } public void updateText() { IResource resource = (IResource) editor.getEditorInput().getAdapter(IResource.class); PluginAdapter adapter = PluginExtensionManager.getDefault().getAdapterByResourceExtension(resource.getFileExtension()); if (adapter == null) { return; } int line = group.getLastSelectedLine() + 1; int start = group.getLastSelectedOffset(); int end = group.isRulerSelected() ? group.getOffsetAtLine(line) : start; if (group.isRulerSelected()) { setEnabled(true); } else { setEnabled(adapter.isToggleBpEnabled(resource, start, end, line)); } } @Override public void run() { try { toggleBreakpoint(); } catch (CoreException e) { } } protected void toggleBreakpoint() throws CoreException { IResource resource = (IResource) editor.getEditorInput().getAdapter(IResource.class); // Hint: doc line numbers start at 0, but markers at 1, therefore + 1 int line = group.getLastSelectedLine() + 1; int start = group.getLastSelectedOffset(); PluginAdapter adapter = PluginExtensionManager.getDefault().getAdapterByResourceExtension(resource.getFileExtension()); if (adapter == null) { return; } // check if a BP already exists on that line and remove it boolean isRulerSelected = group.isRulerSelected(); int end = isRulerSelected ? group.getOffsetAtLine(line) /* Hint: offset after selected line */: start; IBreakpointManager breakpointManager = DebugPlugin.getDefault().getBreakpointManager(); IBreakpoint[] breakpoints = breakpointManager.getBreakpoints(MWEBreakpoint.DEBUG_MODEL_ID); IBreakpoint bp = adapter.checkBreakpoints(breakpoints,resource,start, end, line); if(bp != null){ bp.delete(); return; } // else: register it bp = adapter.createBreakpoint(resource, start, end, line); if (bp == null) { return; } breakpointManager.addBreakpoint(bp); } }