First working prototype of eclipse plugin

This commit is contained in:
konsoletyper 2014-07-31 20:01:56 +04:00
parent 92ba9afee6
commit 930d2087ab
21 changed files with 397 additions and 84 deletions

View File

@ -64,9 +64,10 @@ public final class Parser {
FieldNode fieldNode = (FieldNode)obj; FieldNode fieldNode = (FieldNode)obj;
cls.addField(parseField(fieldNode)); cls.addField(parseField(fieldNode));
} }
String fullFileName = node.name.substring(0, node.name.lastIndexOf('/') + 1) + node.sourceFile;
for (Object obj : node.methods) { for (Object obj : node.methods) {
MethodNode methodNode = (MethodNode)obj; MethodNode methodNode = (MethodNode)obj;
cls.addMethod(parseMethod(methodNode, node.name, node.sourceFile)); cls.addMethod(parseMethod(methodNode, node.name, fullFileName));
} }
if (node.outerClass != null) { if (node.outerClass != null) {
cls.setOwnerName(node.outerClass.replace('/', '.')); cls.setOwnerName(node.outerClass.replace('/', '.'));

View File

@ -1,4 +1,5 @@
/.settings /.settings
/lib
/target /target
/.classpath /.classpath
/.project /.project

View File

@ -0,0 +1,55 @@
Manifest-Version: 1.0
Bundle-ManifestVersion: 2
Bundle-Name: TeaVM plugin for Eclipse
Bundle-SymbolicName: teavm-eclipse-plugin;singleton:=true
Bundle-Version: 0.2.0.SNAPSHOT
Bundle-Vendor: Alexey Andreev <konsoletyper@gmail.com>
Bundle-RequiredExecutionEnvironment: JavaSE-1.7
Require-Bundle: org.eclipse.core.runtime;bundle-version="3.9.0",
org.eclipse.debug.core;bundle-version="3.8.0",
org.eclipse.debug.ui;bundle-version="3.9.0",
org.eclipse.swt;bundle-version="3.102.0",
org.eclipse.ui;bundle-version="3.105.0",
org.eclipse.jdt.debug;bundle-version="3.8.0",
org.eclipse.jdt.debug.ui;bundle-version="3.6.200",
org.eclipse.jdt.core;bundle-version="3.9.2",
org.eclipse.jdt.launching;bundle-version="3.7.1",
org.eclipse.ui.editors;bundle-version="3.8.100",
org.eclipse.ui.ide;bundle-version="3.9.0",
org.eclipse.jdt.ui;bundle-version="3.9.2"
Bundle-ClassPath: lib/asm-5.0.1.jar,
lib/asm-commons-5.0.1.jar,
lib/asm-debug-all-4.2.jar,
lib/asm-tree-5.0.1.jar,
lib/commons-io-2.4.jar,
lib/jackson-core-asl-1.9.13.jar,
lib/jackson-mapper-asl-1.9.13.jar,
lib/javax-websocket-client-impl-9.2.1.v20140609.jar,
lib/javax-websocket-server-impl-9.2.1.v20140609.jar,
lib/javax.annotation-api-1.2.jar,
lib/javax.servlet-api-3.1.0.jar,
lib/javax.websocket-api-1.0.jar,
lib/jetty-annotations-9.2.1.v20140609.jar,
lib/jetty-http-9.2.1.v20140609.jar,
lib/jetty-io-9.2.1.v20140609.jar,
lib/jetty-jndi-9.2.1.v20140609.jar,
lib/jetty-plus-9.2.1.v20140609.jar,
lib/jetty-security-9.2.1.v20140609.jar,
lib/jetty-server-9.2.1.v20140609.jar,
lib/jetty-servlet-9.2.1.v20140609.jar,
lib/jetty-util-9.2.1.v20140609.jar,
lib/jetty-webapp-9.2.1.v20140609.jar,
lib/jetty-xml-9.2.1.v20140609.jar,
lib/slf4j-api-1.7.7.jar,
lib/teavm-chrome-rdp-0.2-SNAPSHOT.jar,
lib/teavm-core-0.2-SNAPSHOT.jar,
lib/websocket-api-9.2.1.v20140609.jar,
lib/websocket-client-9.2.1.v20140609.jar,
lib/websocket-common-9.2.1.v20140609.jar,
lib/websocket-server-9.2.1.v20140609.jar,
lib/websocket-servlet-9.2.1.v20140609.jar,
.,
lib/logback-classic-1.1.2.jar,
lib/logback-core-1.1.2.jar
Export-Package: org.teavm.eclipse.debugger,
org.teavm.eclipse.debugger.ui

View File

@ -0,0 +1,44 @@
source.. = src/main/java/
output.. = target/
bin.includes = plugin.xml,\
META-INF/,\
.,\
lib/asm-5.0.1.jar,\
lib/websocket-servlet-9.2.1.v20140609.jar,\
lib/websocket-server-9.2.1.v20140609.jar,\
lib/websocket-common-9.2.1.v20140609.jar,\
lib/websocket-client-9.2.1.v20140609.jar,\
lib/websocket-api-9.2.1.v20140609.jar,\
lib/teavm-core-0.2-SNAPSHOT.jar,\
lib/teavm-chrome-rdp-0.2-SNAPSHOT.jar,\
lib/slf4j-api-1.7.7.jar,\
lib/jetty-xml-9.2.1.v20140609.jar,\
lib/jetty-webapp-9.2.1.v20140609.jar,\
lib/jetty-util-9.2.1.v20140609.jar,\
lib/jetty-servlet-9.2.1.v20140609.jar,\
lib/jetty-server-9.2.1.v20140609.jar,\
lib/jetty-security-9.2.1.v20140609.jar,\
lib/jetty-plus-9.2.1.v20140609.jar,\
lib/jetty-jndi-9.2.1.v20140609.jar,\
lib/jetty-io-9.2.1.v20140609.jar,\
lib/jetty-http-9.2.1.v20140609.jar,\
lib/jetty-annotations-9.2.1.v20140609.jar,\
lib/javax.websocket-api-1.0.jar,\
lib/javax.servlet-api-3.1.0.jar,\
lib/javax.annotation-api-1.2.jar,\
lib/javax-websocket-server-impl-9.2.1.v20140609.jar,\
lib/javax-websocket-client-impl-9.2.1.v20140609.jar,\
lib/jackson-mapper-asl-1.9.13.jar,\
lib/jackson-core-asl-1.9.13.jar,\
lib/commons-io-2.4.jar,\
lib/asm-tree-5.0.1.jar,\
lib/asm-debug-all-4.2.jar,\
lib/asm-commons-5.0.1.jar,\
logback.xml,\
lib/logback-core-1.1.2.jar,\
lib/logback-classic-1.1.2.jar
source.lib/teavm-core-0.2-SNAPSHOT.jar =
jars.compile.order = .,\
lib/teavm-core-0.2-SNAPSHOT.jar,\
lib/teavm-chrome-rdp-0.2-SNAPSHOT.jar
source.lib/teavm-chrome-rdp-0.2-SNAPSHOT.jar =

View File

@ -0,0 +1,10 @@
<configuration>
<appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">
<encoder>
<pattern>%d{HH:mm:ss.SSS} [%thread] %-5level %logger{36} - %msg%n</pattern>
</encoder>
</appender>
<root level="info">
<appender-ref ref="STDOUT" />
</root>
</configuration>

View File

@ -1,10 +1,11 @@
<?xml version="1.0" encoding="UTF-8"?> <?xml version="1.0" encoding="UTF-8"?>
<?eclipse version="3.0"?> <?eclipse version="3.0"?>
<plugin id="org.teavm.eclipse" version="0.2" name="TeaVM plugin" class="org.teavm.eclipse.TeaVMEclipsePlugin"> <plugin>
<extension point="org.eclipse.debug.core.launchConfigurationTypes"> <extension point="org.eclipse.debug.core.launchConfigurationTypes">
<launchConfigurationType <launchConfigurationType
sourceLocatorId="org.teavm.eclipse.debugger.sourceLookup" sourceLocatorId="org.teavm.eclipse.debugger.sourceLookup"
name="TeaVM remote" name="TeaVM remote"
sourcePathComputerId="org.teavm.eclipse.debugger.sourcePath"
delegate="org.teavm.eclipse.debugger.TeaVMLaunchConfigurationDelegate" delegate="org.teavm.eclipse.debugger.TeaVMLaunchConfigurationDelegate"
modes="debug" modes="debug"
id="org.teavm.eclipse.debugger.launchConfig"> id="org.teavm.eclipse.debugger.launchConfig">
@ -17,6 +18,12 @@
id="org.teavm.eclipse.debugger.sourceLookup"> id="org.teavm.eclipse.debugger.sourceLookup">
</sourceLocator> </sourceLocator>
</extension> </extension>
<extension point="org.eclipse.debug.core.sourcePathComputers">
<sourcePathComputer
class="org.teavm.eclipse.debugger.TeaVMSourcePathComputerDelegate"
id="org.teavm.eclipse.debugger.sourcePath">
</sourcePathComputer>
</extension>
<extension point="org.eclipse.debug.ui.launchConfigurationTabGroups"> <extension point="org.eclipse.debug.ui.launchConfigurationTabGroups">
<launchConfigurationTabGroup <launchConfigurationTabGroup
type="org.teavm.eclipse.debugger.launchConfig" type="org.teavm.eclipse.debugger.launchConfig"
@ -25,4 +32,10 @@
id="org.teavm.eclipse.debugger.ui.tabs"> id="org.teavm.eclipse.debugger.ui.tabs">
</launchConfigurationTabGroup> </launchConfigurationTabGroup>
</extension> </extension>
<extension point="org.eclipse.debug.ui.debugModelPresentations">
<debugModelPresentation
class="org.teavm.eclipse.debugger.TeaVMDebugModelPresentation"
id="org.teavm.eclipse.debugger.thread">
</debugModelPresentation>
</extension>
</plugin> </plugin>

View File

@ -11,13 +11,6 @@
<artifactId>teavm-eclipse</artifactId> <artifactId>teavm-eclipse</artifactId>
<packaging>bundle</packaging> <packaging>bundle</packaging>
<repositories>
<repository>
<id>swt-repo</id>
<url>https://swt-repo.googlecode.com/svn/repo/</url>
</repository>
</repositories>
<dependencies> <dependencies>
<dependency> <dependency>
<groupId>org.teavm</groupId> <groupId>org.teavm</groupId>
@ -30,14 +23,9 @@
<version>${project.version}</version> <version>${project.version}</version>
</dependency> </dependency>
<dependency> <dependency>
<groupId>org.eclipse.core</groupId> <groupId>ch.qos.logback</groupId>
<artifactId>runtime</artifactId> <artifactId>logback-classic</artifactId>
<version>3.9.100-v20131218-1515</version> <version>1.1.2</version>
</dependency>
<dependency>
<groupId>org.eclipse.swt</groupId>
<artifactId>org.eclipse.swt.win32.win32.x86</artifactId>
<version>4.2.2</version>
</dependency> </dependency>
</dependencies> </dependencies>
@ -54,6 +42,17 @@
</instructions> </instructions>
</configuration> </configuration>
</plugin> </plugin>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-dependency-plugin</artifactId>
<version>2.8</version>
<goals>
<goal>dependency:copy-dependencies</goal>
</goals>
<configuration>
<outputDirectory>${basedir}/lib</outputDirectory>
</configuration>
</plugin>
</plugins> </plugins>
</build> </build>

View File

@ -0,0 +1,52 @@
package org.teavm.eclipse.debugger;
import org.eclipse.core.resources.IFile;
import org.eclipse.debug.core.model.ILineBreakpoint;
import org.eclipse.debug.core.model.IValue;
import org.eclipse.debug.ui.IDebugModelPresentation;
import org.eclipse.debug.ui.IValueDetailListener;
import org.eclipse.jdt.ui.JavaUI;
import org.eclipse.jface.viewers.LabelProvider;
import org.eclipse.ui.IEditorInput;
import org.eclipse.ui.part.FileEditorInput;
/**
*
* @author Alexey Andreev <konsoletyper@gmail.com>
*/
public class TeaVMDebugModelPresentation extends LabelProvider implements IDebugModelPresentation {
@Override
public String getEditorId(IEditorInput input, Object element) {
if (element instanceof IFile || element instanceof ILineBreakpoint) {
return JavaUI.ID_CU_EDITOR;
}
return null;
}
@Override
public IEditorInput getEditorInput(Object element) {
if (element instanceof IFile) {
return new FileEditorInput((IFile)element);
}
if (element instanceof ILineBreakpoint) {
return new FileEditorInput((IFile)((ILineBreakpoint)element).getMarker().getResource());
}
return null;
}
@Override
public void computeDetail(IValue arg0, IValueDetailListener arg1) {
}
@Override
public void setAttribute(String arg0, Object arg1) {
}
@Override
public String getText(Object element) {
if (element instanceof TeaVMStackFrame) {
return ((TeaVMStackFrame)element).getName();
}
return super.getText(element);
}
}

View File

@ -2,19 +2,14 @@ package org.teavm.eclipse.debugger;
import java.util.HashMap; import java.util.HashMap;
import java.util.Map; import java.util.Map;
import org.eclipse.core.resources.IMarker;
import org.eclipse.core.resources.IMarkerDelta; import org.eclipse.core.resources.IMarkerDelta;
import org.eclipse.core.resources.IResource;
import org.eclipse.core.runtime.CoreException; import org.eclipse.core.runtime.CoreException;
import org.eclipse.debug.core.DebugEvent; import org.eclipse.debug.core.DebugEvent;
import org.eclipse.debug.core.DebugException; import org.eclipse.debug.core.DebugException;
import org.eclipse.debug.core.DebugPlugin; import org.eclipse.debug.core.DebugPlugin;
import org.eclipse.debug.core.ILaunch; import org.eclipse.debug.core.ILaunch;
import org.eclipse.debug.core.model.IBreakpoint; import org.eclipse.debug.core.model.*;
import org.eclipse.debug.core.model.IDebugTarget; import org.eclipse.jdt.debug.core.IJavaLineBreakpoint;
import org.eclipse.debug.core.model.IMemoryBlock;
import org.eclipse.debug.core.model.IProcess;
import org.eclipse.debug.core.model.IThread;
import org.teavm.chromerdp.ChromeRDPServer; import org.teavm.chromerdp.ChromeRDPServer;
import org.teavm.debugging.Breakpoint; import org.teavm.debugging.Breakpoint;
import org.teavm.debugging.Debugger; import org.teavm.debugging.Debugger;
@ -25,12 +20,13 @@ import org.teavm.debugging.DebuggerListener;
* @author Alexey Andreev <konsoletyper@gmail.com> * @author Alexey Andreev <konsoletyper@gmail.com>
*/ */
@SuppressWarnings("rawtypes") @SuppressWarnings("rawtypes")
public class TeaVMDebugTarget implements IDebugTarget { public class TeaVMDebugTarget implements IDebugTarget, IStep {
ILaunch launch; ILaunch launch;
Debugger teavmDebugger; Debugger teavmDebugger;
private ChromeRDPServer server; private ChromeRDPServer server;
private boolean terminated; private boolean terminated;
private TeaVMDebugProcess process; private TeaVMDebugProcess process;
private TeaVMThread thread;
Map<IBreakpoint, Breakpoint> breakpointMap = new HashMap<>(); Map<IBreakpoint, Breakpoint> breakpointMap = new HashMap<>();
Map<Breakpoint, IBreakpoint> breakpointBackMap = new HashMap<>(); Map<Breakpoint, IBreakpoint> breakpointBackMap = new HashMap<>();
@ -39,6 +35,11 @@ public class TeaVMDebugTarget implements IDebugTarget {
this.teavmDebugger = teavmDebugger; this.teavmDebugger = teavmDebugger;
this.server = server; this.server = server;
this.process = new TeaVMDebugProcess(launch); this.process = new TeaVMDebugProcess(launch);
this.thread = new TeaVMThread(this);
DebugPlugin.getDefault().getBreakpointManager().addBreakpointListener(this);
for (IBreakpoint breakpoint : DebugPlugin.getDefault().getBreakpointManager().getBreakpoints()) {
breakpointAdded(breakpoint);
}
teavmDebugger.addListener(new DebuggerListener() { teavmDebugger.addListener(new DebuggerListener() {
@Override @Override
public void resumed() { public void resumed() {
@ -88,6 +89,7 @@ public class TeaVMDebugTarget implements IDebugTarget {
public void terminate() throws DebugException { public void terminate() throws DebugException {
terminated = true; terminated = true;
server.stop(); server.stop();
fireEvent(new DebugEvent(this, DebugEvent.TERMINATE));
} }
@Override @Override
@ -98,25 +100,25 @@ public class TeaVMDebugTarget implements IDebugTarget {
@Override @Override
public void breakpointAdded(IBreakpoint breakpoint) { public void breakpointAdded(IBreakpoint breakpoint) {
try { try {
if (breakpoint instanceof IJavaLineBreakpoint) {
IJavaLineBreakpoint lineBreakpoint = (IJavaLineBreakpoint)breakpoint;
String fileName = lineBreakpoint.getTypeName().replace('.', '/') + ".java";
Breakpoint teavmBreakpoint = teavmDebugger.createBreakpoint(fileName, lineBreakpoint.getLineNumber());
breakpointMap.put(lineBreakpoint, teavmBreakpoint);
breakpointBackMap.put(teavmBreakpoint, lineBreakpoint);
breakpoint.setRegistered(true); breakpoint.setRegistered(true);
int line = breakpoint.getMarker().getAttribute(IMarker.LINE_NUMBER, 1); } else {
String fileName = getRelativePath(breakpoint.getMarker().getResource()); breakpoint.setRegistered(false);
teavmDebugger.createBreakpoint(fileName, line); }
} catch (CoreException e) { } catch (CoreException e) {
throw new RuntimeException(e); throw new RuntimeException(e);
} }
} }
private String getRelativePath(IResource resource) {
if ((resource.getType() & IResource.PROJECT) != 0 ||
(resource.getType() & IResource.VIRTUAL) != 0) {
return "";
}
return getRelativePath(resource.getParent()) + "/" + resource.getName();
}
@Override @Override
public void breakpointChanged(IBreakpoint arg0, IMarkerDelta arg1) { public void breakpointChanged(IBreakpoint breakpoint, IMarkerDelta markerDelta) {
breakpointRemoved(breakpoint, markerDelta);
breakpointAdded(breakpoint);
} }
@Override @Override
@ -189,7 +191,7 @@ public class TeaVMDebugTarget implements IDebugTarget {
@Override @Override
public boolean isDisconnected() { public boolean isDisconnected() {
return teavmDebugger.isAttached(); return !teavmDebugger.isAttached();
} }
@Override @Override
@ -204,7 +206,7 @@ public class TeaVMDebugTarget implements IDebugTarget {
@Override @Override
public IThread[] getThreads() throws DebugException { public IThread[] getThreads() throws DebugException {
return null; return new IThread[] { thread };
} }
@Override @Override
@ -214,11 +216,41 @@ public class TeaVMDebugTarget implements IDebugTarget {
@Override @Override
public boolean supportsBreakpoint(IBreakpoint breakpoint) { public boolean supportsBreakpoint(IBreakpoint breakpoint) {
try { return breakpoint instanceof IJavaLineBreakpoint;
return breakpoint.getMarker().getAttribute(IMarker.LINE_NUMBER) != null; }
} catch (CoreException e) {
// TODO: Log this exception @Override
public boolean canStepInto() {
return true;
}
@Override
public boolean canStepOver() {
return true;
}
@Override
public boolean canStepReturn() {
return true;
}
@Override
public boolean isStepping() {
return false; return false;
} }
@Override
public void stepInto() throws DebugException {
thread.stepInto();
}
@Override
public void stepOver() throws DebugException {
thread.stepOver();
}
@Override
public void stepReturn() throws DebugException {
thread.stepReturn();
} }
} }

View File

@ -9,7 +9,7 @@ import org.eclipse.debug.core.ILaunch;
import org.eclipse.debug.core.ILaunchConfiguration; import org.eclipse.debug.core.ILaunchConfiguration;
import org.eclipse.debug.core.ILaunchManager; import org.eclipse.debug.core.ILaunchManager;
import org.eclipse.debug.core.model.ILaunchConfigurationDelegate; import org.eclipse.debug.core.model.ILaunchConfigurationDelegate;
import org.eclipse.swt.widgets.Display; import org.eclipse.ui.PlatformUI;
import org.teavm.chromerdp.*; import org.teavm.chromerdp.*;
import org.teavm.debugging.Debugger; import org.teavm.debugging.Debugger;
import org.teavm.debugging.URLDebugInformationProvider; import org.teavm.debugging.URLDebugInformationProvider;
@ -26,14 +26,17 @@ public class TeaVMLaunchConfigurationDelegate implements ILaunchConfigurationDel
throw new IllegalArgumentException("Only debug mode supported"); throw new IllegalArgumentException("Only debug mode supported");
} }
int port = configuration.getAttribute("teavm-debugger-port", 2357); int port = configuration.getAttribute("teavm-debugger-port", 2357);
ChromeRDPServer server = new ChromeRDPServer(); final ChromeRDPServer server = new ChromeRDPServer();
server.setPort(port); server.setPort(port);
ChromeRDPDebugger jsDebugger = new ChromeRDPDebugger(); ChromeRDPDebugger jsDebugger = new ChromeRDPDebugger();
server.setExchangeConsumer(new SynchronousMessageExchange(jsDebugger)); server.setExchangeConsumer(new SynchronousMessageExchange(jsDebugger));
Debugger debugger = new Debugger(jsDebugger, new URLDebugInformationProvider("")); Debugger debugger = new Debugger(jsDebugger, new URLDebugInformationProvider(""));
new Thread() {
@Override public void run() {
server.start(); server.start();
}
}.start();
launch.addDebugTarget(new TeaVMDebugTarget(launch, debugger, server)); launch.addDebugTarget(new TeaVMDebugTarget(launch, debugger, server));
monitor.done();
} }
private static class SynchronousMessageExchange implements ChromeRDPExchangeConsumer, private static class SynchronousMessageExchange implements ChromeRDPExchangeConsumer,
@ -52,7 +55,13 @@ public class TeaVMLaunchConfigurationDelegate implements ILaunchConfigurationDel
debugger.setExchange(this); debugger.setExchange(this);
exchange.addListener(new ChromeRDPExchangeListener() { exchange.addListener(new ChromeRDPExchangeListener() {
@Override public void received(final String message) throws IOException { @Override public void received(final String message) throws IOException {
Display.getCurrent().asyncExec(new Runnable() { postToUIThread(message);
}
});
}
private void postToUIThread(final String message) {
PlatformUI.getWorkbench().getDisplay().asyncExec(new Runnable() {
@Override public void run() { @Override public void run() {
try { try {
for (ChromeRDPExchangeListener listener : listeners) { for (ChromeRDPExchangeListener listener : listeners) {
@ -64,8 +73,6 @@ public class TeaVMLaunchConfigurationDelegate implements ILaunchConfigurationDel
} }
}); });
} }
});
}
@Override @Override
public void send(String message) { public void send(String message) {

View File

@ -11,11 +11,11 @@ import org.teavm.debugging.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;
} }
return null;
}
} }

View File

@ -0,0 +1,43 @@
package org.teavm.eclipse.debugger;
import java.util.ArrayList;
import java.util.List;
import org.eclipse.core.resources.IFolder;
import org.eclipse.core.resources.IProject;
import org.eclipse.core.resources.ResourcesPlugin;
import org.eclipse.core.runtime.CoreException;
import org.eclipse.core.runtime.IProgressMonitor;
import org.eclipse.debug.core.ILaunchConfiguration;
import org.eclipse.debug.core.sourcelookup.ISourceContainer;
import org.eclipse.debug.core.sourcelookup.ISourcePathComputerDelegate;
import org.eclipse.debug.core.sourcelookup.containers.FolderSourceContainer;
import org.eclipse.jdt.core.IJavaProject;
import org.eclipse.jdt.core.IPackageFragmentRoot;
import org.eclipse.jdt.core.JavaCore;
/**
*
* @author Alexey Andreev <konsoletyper@gmail.com>
*/
public class TeaVMSourcePathComputerDelegate implements ISourcePathComputerDelegate {
@Override
public ISourceContainer[] computeSourceContainers(ILaunchConfiguration config, IProgressMonitor monitor)
throws CoreException {
List<ISourceContainer> sourceContainers = new ArrayList<>();
IProject[] projects = ResourcesPlugin.getWorkspace().getRoot().getProjects();
for (IProject project : projects) {
if (!project.isOpen()) {
continue;
}
if (project.hasNature(JavaCore.NATURE_ID)) {
IJavaProject javaProject = JavaCore.create(project);
for (IPackageFragmentRoot fragmentRoot : javaProject.getAllPackageFragmentRoots()) {
if (fragmentRoot.getResource() instanceof IFolder) {
sourceContainers.add(new FolderSourceContainer((IFolder)fragmentRoot.getResource(), true));
}
}
}
}
return sourceContainers.toArray(new ISourceContainer[0]);
}
}

View File

@ -2,11 +2,7 @@ package org.teavm.eclipse.debugger;
import org.eclipse.debug.core.DebugException; import org.eclipse.debug.core.DebugException;
import org.eclipse.debug.core.ILaunch; import org.eclipse.debug.core.ILaunch;
import org.eclipse.debug.core.model.IDebugTarget; import org.eclipse.debug.core.model.*;
import org.eclipse.debug.core.model.IRegisterGroup;
import org.eclipse.debug.core.model.IStackFrame;
import org.eclipse.debug.core.model.IThread;
import org.eclipse.debug.core.model.IVariable;
import org.teavm.debugging.CallFrame; import org.teavm.debugging.CallFrame;
/** /**
@ -43,17 +39,17 @@ public class TeaVMStackFrame implements IStackFrame {
@Override @Override
public boolean canStepInto() { public boolean canStepInto() {
return false; return thread.getTopStackFrame() == this;
} }
@Override @Override
public boolean canStepOver() { public boolean canStepOver() {
return false; return thread.getTopStackFrame() == this;
} }
@Override @Override
public boolean canStepReturn() { public boolean canStepReturn() {
return false; return thread.getTopStackFrame() == this;
} }
@Override @Override
@ -63,14 +59,17 @@ public class TeaVMStackFrame implements IStackFrame {
@Override @Override
public void stepInto() throws DebugException { public void stepInto() throws DebugException {
thread.stepInto();
} }
@Override @Override
public void stepOver() throws DebugException { public void stepOver() throws DebugException {
thread.stepOver();
} }
@Override @Override
public void stepReturn() throws DebugException { public void stepReturn() throws DebugException {
thread.stepReturn();
} }
@Override @Override
@ -80,20 +79,22 @@ public class TeaVMStackFrame implements IStackFrame {
@Override @Override
public boolean canSuspend() { public boolean canSuspend() {
return false; return thread.getTopStackFrame() == this;
} }
@Override @Override
public boolean isSuspended() { public boolean isSuspended() {
return false; return thread.isSuspended();
} }
@Override @Override
public void resume() throws DebugException { public void resume() throws DebugException {
thread.resume();
} }
@Override @Override
public void suspend() throws DebugException { public void suspend() throws DebugException {
thread.suspend();
} }
@Override @Override
@ -108,7 +109,7 @@ public class TeaVMStackFrame implements IStackFrame {
@Override @Override
public String getModelIdentifier() { public String getModelIdentifier() {
return thread.getModelIdentifier(); return thread.getModelIdentifier() + ".thread";
} }
@Override @Override
@ -127,8 +128,14 @@ public class TeaVMStackFrame implements IStackFrame {
} }
@Override @Override
public String getName() throws DebugException { public String getName() {
return callFrame.getLocation() != null ? callFrame.getLocation().getFileName() : "unknown"; StringBuilder sb = new StringBuilder();
String fileName = callFrame.getLocation() != null ? callFrame.getLocation().getFileName() : null;
sb.append(fileName != null ? fileName : "unknown");
if (callFrame.getLocation() != null) {
sb.append(":").append(callFrame.getLocation().getLine());
}
return sb.toString();
} }
@Override @Override

View File

@ -1,12 +1,17 @@
package org.teavm.eclipse.debugger; package org.teavm.eclipse.debugger;
import org.eclipse.debug.core.DebugEvent;
import org.eclipse.debug.core.DebugException; import org.eclipse.debug.core.DebugException;
import org.eclipse.debug.core.DebugPlugin;
import org.eclipse.debug.core.ILaunch; import org.eclipse.debug.core.ILaunch;
import org.eclipse.debug.core.model.IBreakpoint; import org.eclipse.debug.core.model.IBreakpoint;
import org.eclipse.debug.core.model.IDebugTarget; import org.eclipse.debug.core.model.IDebugTarget;
import org.eclipse.debug.core.model.IStackFrame; import org.eclipse.debug.core.model.IStackFrame;
import org.eclipse.debug.core.model.IThread; import org.eclipse.debug.core.model.IThread;
import org.teavm.debugging.Breakpoint;
import org.teavm.debugging.CallFrame;
import org.teavm.debugging.Debugger; import org.teavm.debugging.Debugger;
import org.teavm.debugging.DebuggerListener;
/** /**
* *
@ -15,10 +20,52 @@ import org.teavm.debugging.Debugger;
public class TeaVMThread implements IThread { public class TeaVMThread implements IThread {
private Debugger teavmDebugger; private Debugger teavmDebugger;
private TeaVMDebugTarget debugTarget; private TeaVMDebugTarget debugTarget;
private TeaVMStackFrame[] stackTrace;
public TeaVMThread(TeaVMDebugTarget debugTarget) { public TeaVMThread(TeaVMDebugTarget debugTarget) {
this.debugTarget = debugTarget; this.debugTarget = debugTarget;
this.teavmDebugger = debugTarget.teavmDebugger; this.teavmDebugger = debugTarget.teavmDebugger;
this.teavmDebugger.addListener(new DebuggerListener() {
@Override
public void resumed() {
updateStackTrace();
}
@Override
public void paused() {
updateStackTrace();
}
@Override
public void detached() {
}
@Override
public void breakpointStatusChanged(Breakpoint breakpoint) {
}
@Override
public void attached() {
}
});
}
private void updateStackTrace() {
if (teavmDebugger.getCallStack() == null) {
stackTrace = null;
} else {
CallFrame[] teavmCallStack = teavmDebugger.getCallStack();
stackTrace = new TeaVMStackFrame[teavmCallStack.length];
for (int i = 0; i < teavmCallStack.length; ++i) {
CallFrame teavmFrame = teavmCallStack[i];
stackTrace[i] = new TeaVMStackFrame(this, teavmFrame);
}
}
fireEvent(new DebugEvent(this, DebugEvent.CHANGE));
}
private void fireEvent(DebugEvent event) {
DebugPlugin.getDefault().fireDebugEventSet(new DebugEvent[] { event });
} }
@Override @Override
@ -43,12 +90,12 @@ public class TeaVMThread implements IThread {
@Override @Override
public boolean canResume() { public boolean canResume() {
return false; return true;
} }
@Override @Override
public boolean canSuspend() { public boolean canSuspend() {
return false; return true;
} }
@Override @Override
@ -58,10 +105,12 @@ public class TeaVMThread implements IThread {
@Override @Override
public void resume() throws DebugException { public void resume() throws DebugException {
teavmDebugger.resume();
} }
@Override @Override
public void suspend() throws DebugException { public void suspend() throws DebugException {
teavmDebugger.suspend();
} }
@Override @Override
@ -131,12 +180,12 @@ public class TeaVMThread implements IThread {
@Override @Override
public IStackFrame[] getStackFrames() throws DebugException { public IStackFrame[] getStackFrames() throws DebugException {
return null; return stackTrace != null ? stackTrace.clone() : new IStackFrame[0];
} }
@Override @Override
public IStackFrame getTopStackFrame() throws DebugException { public IStackFrame getTopStackFrame() {
return null; return stackTrace != null && stackTrace.length > 0 ? stackTrace[0] : null;
} }
@Override @Override

View File

@ -43,7 +43,7 @@ public class TeaVMTab extends AbstractLaunchConfigurationTab {
@Override @Override
public String getName() { public String getName() {
return null; return "TeaVM";
} }
@Override @Override