mirror of
https://github.com/Eaglercraft-TeaVM-Fork/eagler-teavm.git
synced 2025-01-12 09:34:49 -08:00
Adds UI for viewing JavaScript file in debugger
This commit is contained in:
parent
238cb69fb9
commit
94855d04d0
teavm-eclipse/teavm-eclipse-plugin
META-INF
src/main/java/org/teavm/eclipse/debugger
|
@ -17,7 +17,8 @@ Require-Bundle: org.eclipse.core.runtime;bundle-version="[3.8.0,4.0)",
|
||||||
org.eclipse.jdt.launching;bundle-version="[3.6.1,4.0.0)",
|
org.eclipse.jdt.launching;bundle-version="[3.6.1,4.0.0)",
|
||||||
org.eclipse.ui.editors;bundle-version="[3.8.0,4.0.0)",
|
org.eclipse.ui.editors;bundle-version="[3.8.0,4.0.0)",
|
||||||
org.eclipse.ui.ide;bundle-version="[3.8.2,4.0.0)",
|
org.eclipse.ui.ide;bundle-version="[3.8.2,4.0.0)",
|
||||||
org.eclipse.jdt.ui;bundle-version="[3.8.2,4.0.0)"
|
org.eclipse.jdt.ui;bundle-version="[3.8.2,4.0.0)",
|
||||||
|
org.eclipse.core.filesystem;bundle-version="1.4.0"
|
||||||
Bundle-ClassPath: .,
|
Bundle-ClassPath: .,
|
||||||
lib/asm-5.0.1.jar,
|
lib/asm-5.0.1.jar,
|
||||||
lib/asm-commons-5.0.1.jar,
|
lib/asm-commons-5.0.1.jar,
|
||||||
|
|
|
@ -136,12 +136,12 @@ public class TeaVMJSStackFrame implements IStackFrame {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public int getCharEnd() throws DebugException {
|
public int getCharEnd() throws DebugException {
|
||||||
return callFrame.getLocation() != null ? callFrame.getLocation().getColumn() + 2 : -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public int getCharStart() throws DebugException {
|
public int getCharStart() throws DebugException {
|
||||||
return callFrame.getLocation() != null ? callFrame.getLocation().getColumn() + 1 : -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|
|
@ -15,9 +15,13 @@
|
||||||
*/
|
*/
|
||||||
package org.teavm.eclipse.debugger;
|
package org.teavm.eclipse.debugger;
|
||||||
|
|
||||||
|
import java.net.MalformedURLException;
|
||||||
|
import java.net.URL;
|
||||||
|
import java.util.Arrays;
|
||||||
import org.eclipse.core.runtime.CoreException;
|
import org.eclipse.core.runtime.CoreException;
|
||||||
import org.eclipse.debug.core.sourcelookup.AbstractSourceLookupParticipant;
|
import org.eclipse.debug.core.sourcelookup.AbstractSourceLookupParticipant;
|
||||||
import org.teavm.debugging.information.SourceLocation;
|
import org.teavm.debugging.information.SourceLocation;
|
||||||
|
import org.teavm.debugging.javascript.JavaScriptLocation;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
|
@ -26,11 +30,38 @@ import org.teavm.debugging.information.SourceLocation;
|
||||||
public class TeaVMSourceLookupParticipant extends AbstractSourceLookupParticipant {
|
public class TeaVMSourceLookupParticipant extends AbstractSourceLookupParticipant {
|
||||||
@Override
|
@Override
|
||||||
public String getSourceName(Object object) throws CoreException {
|
public String getSourceName(Object object) throws CoreException {
|
||||||
if (!(object instanceof TeaVMStackFrame)) {
|
if (object instanceof TeaVMStackFrame) {
|
||||||
return null;
|
|
||||||
}
|
|
||||||
TeaVMStackFrame stackFrame = (TeaVMStackFrame)object;
|
TeaVMStackFrame stackFrame = (TeaVMStackFrame)object;
|
||||||
SourceLocation location = stackFrame.callFrame.getLocation();
|
SourceLocation location = stackFrame.callFrame.getLocation();
|
||||||
return location != null ? location.getFileName() : null;
|
return location != null ? location.getFileName() : null;
|
||||||
|
} else if (object instanceof TeaVMJSStackFrame) {
|
||||||
|
TeaVMJSStackFrame stackFrame = (TeaVMJSStackFrame)object;
|
||||||
|
JavaScriptLocation location = stackFrame.callFrame.getLocation();
|
||||||
|
return location != null ? location.getScript() : null;
|
||||||
|
} else {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Object[] findSourceElements(Object object) throws CoreException {
|
||||||
|
Object[] result = super.findSourceElements(object);
|
||||||
|
if (object instanceof TeaVMJSStackFrame) {
|
||||||
|
TeaVMJSStackFrame stackFrame = (TeaVMJSStackFrame)object;
|
||||||
|
JavaScriptLocation location = stackFrame.getCallFrame().getLocation();
|
||||||
|
if (location != null) {
|
||||||
|
URL url;
|
||||||
|
try {
|
||||||
|
url = new URL(location.getScript());
|
||||||
|
} catch (MalformedURLException e) {
|
||||||
|
url = null;
|
||||||
|
}
|
||||||
|
if (url != null) {
|
||||||
|
result = Arrays.copyOf(result, result.length + 1);
|
||||||
|
result[result.length - 1] = url;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return result;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -15,6 +15,11 @@
|
||||||
*/
|
*/
|
||||||
package org.teavm.eclipse.debugger.ui;
|
package org.teavm.eclipse.debugger.ui;
|
||||||
|
|
||||||
|
import java.net.URI;
|
||||||
|
import java.net.URISyntaxException;
|
||||||
|
import java.net.URL;
|
||||||
|
import org.eclipse.core.filesystem.EFS;
|
||||||
|
import org.eclipse.core.filesystem.IFileStore;
|
||||||
import org.eclipse.core.resources.IFile;
|
import org.eclipse.core.resources.IFile;
|
||||||
import org.eclipse.debug.core.model.ILineBreakpoint;
|
import org.eclipse.debug.core.model.ILineBreakpoint;
|
||||||
import org.eclipse.debug.core.model.IValue;
|
import org.eclipse.debug.core.model.IValue;
|
||||||
|
@ -23,6 +28,8 @@ import org.eclipse.debug.ui.IValueDetailListener;
|
||||||
import org.eclipse.jdt.ui.JavaUI;
|
import org.eclipse.jdt.ui.JavaUI;
|
||||||
import org.eclipse.jface.viewers.LabelProvider;
|
import org.eclipse.jface.viewers.LabelProvider;
|
||||||
import org.eclipse.ui.IEditorInput;
|
import org.eclipse.ui.IEditorInput;
|
||||||
|
import org.eclipse.ui.editors.text.EditorsUI;
|
||||||
|
import org.eclipse.ui.ide.FileStoreEditorInput;
|
||||||
import org.eclipse.ui.part.FileEditorInput;
|
import org.eclipse.ui.part.FileEditorInput;
|
||||||
import org.teavm.debugging.CallFrame;
|
import org.teavm.debugging.CallFrame;
|
||||||
import org.teavm.debugging.javascript.JavaScriptCallFrame;
|
import org.teavm.debugging.javascript.JavaScriptCallFrame;
|
||||||
|
@ -41,6 +48,8 @@ public class TeaVMDebugModelPresentation extends LabelProvider implements IDebug
|
||||||
public String getEditorId(IEditorInput input, Object element) {
|
public String getEditorId(IEditorInput input, Object element) {
|
||||||
if (element instanceof IFile || element instanceof ILineBreakpoint) {
|
if (element instanceof IFile || element instanceof ILineBreakpoint) {
|
||||||
return JavaUI.ID_CU_EDITOR;
|
return JavaUI.ID_CU_EDITOR;
|
||||||
|
} else if (element instanceof URL) {
|
||||||
|
return EditorsUI.DEFAULT_TEXT_EDITOR_ID;
|
||||||
}
|
}
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
@ -53,6 +62,15 @@ public class TeaVMDebugModelPresentation extends LabelProvider implements IDebug
|
||||||
if (element instanceof ILineBreakpoint) {
|
if (element instanceof ILineBreakpoint) {
|
||||||
return new FileEditorInput((IFile)((ILineBreakpoint)element).getMarker().getResource());
|
return new FileEditorInput((IFile)((ILineBreakpoint)element).getMarker().getResource());
|
||||||
}
|
}
|
||||||
|
if (element instanceof URL) {
|
||||||
|
try {
|
||||||
|
URI uri = new URI(element.toString());
|
||||||
|
IFileStore store = EFS.getLocalFileSystem().getStore(uri);
|
||||||
|
return new FileStoreEditorInput(store);
|
||||||
|
} catch (URISyntaxException e) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
}
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue
Block a user