mirror of
https://github.com/Eaglercraft-TeaVM-Fork/eagler-teavm.git
synced 2025-01-08 07:54:11 -08:00
First attempt to create a TeaVM eclipse plugin
This commit is contained in:
parent
25789825fc
commit
4b43cbce55
|
@ -83,6 +83,17 @@
|
|||
<groupId>org.apache.maven.plugins</groupId>
|
||||
<artifactId>maven-javadoc-plugin</artifactId>
|
||||
</plugin>
|
||||
<plugin>
|
||||
<groupId>org.apache.felix</groupId>
|
||||
<artifactId>maven-bundle-plugin</artifactId>
|
||||
<extensions>true</extensions>
|
||||
<configuration>
|
||||
<instructions>
|
||||
<Export-Package>org.teavm.chromerdp</Export-Package>
|
||||
<Bundle-SymbolicName>teavm-chrome-rdp</Bundle-SymbolicName>
|
||||
</instructions>
|
||||
</configuration>
|
||||
</plugin>
|
||||
</plugins>
|
||||
</build>
|
||||
</project>
|
|
@ -33,6 +33,7 @@ import org.eclipse.jetty.websocket.jsr356.server.deploy.WebSocketServerContainer
|
|||
public class ChromeRDPServer {
|
||||
private int port = 2357;
|
||||
private ChromeRDPExchangeConsumer exchangeConsumer;
|
||||
private Server server;
|
||||
|
||||
public int getPort() {
|
||||
return port;
|
||||
|
@ -51,7 +52,7 @@ public class ChromeRDPServer {
|
|||
}
|
||||
|
||||
public void start() {
|
||||
final Server server = new Server();
|
||||
server = new Server();
|
||||
ServerConnector connector = new ServerConnector(server);
|
||||
connector.setPort(port);
|
||||
server.addConnector(connector);
|
||||
|
@ -71,6 +72,14 @@ public class ChromeRDPServer {
|
|||
}
|
||||
}
|
||||
|
||||
public void stop() {
|
||||
try {
|
||||
server.stop();
|
||||
} catch (Exception e) {
|
||||
throw new RuntimeException(e);
|
||||
}
|
||||
}
|
||||
|
||||
private class RPDEndpointConfig implements ServerEndpointConfig {
|
||||
private Map<String, Object> userProperties = new HashMap<>();
|
||||
|
||||
|
|
|
@ -24,6 +24,8 @@
|
|||
</parent>
|
||||
<artifactId>teavm-core</artifactId>
|
||||
|
||||
<packaging>bundle</packaging>
|
||||
|
||||
<dependencies>
|
||||
<dependency>
|
||||
<groupId>junit</groupId>
|
||||
|
@ -75,6 +77,17 @@
|
|||
<groupId>org.apache.maven.plugins</groupId>
|
||||
<artifactId>maven-javadoc-plugin</artifactId>
|
||||
</plugin>
|
||||
<plugin>
|
||||
<groupId>org.apache.felix</groupId>
|
||||
<artifactId>maven-bundle-plugin</artifactId>
|
||||
<extensions>true</extensions>
|
||||
<configuration>
|
||||
<instructions>
|
||||
<Export-Package>org.teavm.*</Export-Package>
|
||||
<Bundle-SymbolicName>teavm-core</Bundle-SymbolicName>
|
||||
</instructions>
|
||||
</configuration>
|
||||
</plugin>
|
||||
</plugins>
|
||||
</build>
|
||||
|
||||
|
|
4
teavm-eclipse/.gitignore
vendored
Normal file
4
teavm-eclipse/.gitignore
vendored
Normal file
|
@ -0,0 +1,4 @@
|
|||
/.settings
|
||||
/target
|
||||
/.classpath
|
||||
/.project
|
11
teavm-eclipse/META-INF/MANIFEST.MF
Normal file
11
teavm-eclipse/META-INF/MANIFEST.MF
Normal file
|
@ -0,0 +1,11 @@
|
|||
Manifest-Version: 1.0
|
||||
Bundle-ManifestVersion: 2
|
||||
Bundle-Name: TeaVM eclipse support
|
||||
Bundle-SymbolicName: teavm-eclipse;singleton:=true
|
||||
Bundle-Version: 0.2.0
|
||||
Bundle-RequiredExecutionEnvironment: JavaSE-1.7
|
||||
Require-Bundle: org.eclipse.debug.core;bundle-version="3.8.0",
|
||||
org.eclipse.debug.ui;bundle-version="3.9.0",
|
||||
org.eclipse.core.runtime;bundle-version="3.9.0",
|
||||
org.eclipse.swt;bundle-version="3.102.0",
|
||||
org.eclipse.jdt.debug;bundle-version="3.8.0"
|
4
teavm-eclipse/build.properties
Normal file
4
teavm-eclipse/build.properties
Normal file
|
@ -0,0 +1,4 @@
|
|||
source.. = src/main/java/
|
||||
output.. = target/
|
||||
bin.includes = META-INF/,\
|
||||
.
|
5
teavm-eclipse/plugin.xml
Normal file
5
teavm-eclipse/plugin.xml
Normal file
|
@ -0,0 +1,5 @@
|
|||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<?eclipse version="3.0"?>
|
||||
<plugin id="org.teavm.eclipse" name="TeaVM plugin" version="1.0">
|
||||
|
||||
</plugin>
|
|
@ -0,0 +1,199 @@
|
|||
package org.teavm.eclipse.debugger;
|
||||
|
||||
import org.eclipse.core.resources.IMarkerDelta;
|
||||
import org.eclipse.core.runtime.CoreException;
|
||||
import org.eclipse.debug.core.DebugEvent;
|
||||
import org.eclipse.debug.core.DebugException;
|
||||
import org.eclipse.debug.core.DebugPlugin;
|
||||
import org.eclipse.debug.core.ILaunch;
|
||||
import org.eclipse.debug.core.model.IBreakpoint;
|
||||
import org.eclipse.debug.core.model.IDebugTarget;
|
||||
import org.eclipse.debug.core.model.ILineBreakpoint;
|
||||
import org.eclipse.debug.core.model.IMemoryBlock;
|
||||
import org.eclipse.debug.core.model.IProcess;
|
||||
import org.eclipse.debug.core.model.IThread;
|
||||
import org.eclipse.jdt.debug.core.IJavaLineBreakpoint;
|
||||
import org.teavm.chromerdp.ChromeRDPServer;
|
||||
import org.teavm.debugging.Breakpoint;
|
||||
import org.teavm.debugging.Debugger;
|
||||
import org.teavm.debugging.DebuggerListener;
|
||||
|
||||
/**
|
||||
*
|
||||
* @author Alexey Andreev <konsoletyper@gmail.com>
|
||||
*/
|
||||
@SuppressWarnings("rawtypes")
|
||||
public class TeaVMDebugTarget implements IDebugTarget {
|
||||
private ILaunch launch;
|
||||
private Debugger teavmDebugger;
|
||||
private ChromeRDPServer server;
|
||||
private boolean terminated;
|
||||
|
||||
public TeaVMDebugTarget(ILaunch launch, Debugger teavmDebugger, ChromeRDPServer server) {
|
||||
this.launch = launch;
|
||||
this.teavmDebugger = teavmDebugger;
|
||||
this.server = server;
|
||||
teavmDebugger.addListener(new DebuggerListener() {
|
||||
@Override
|
||||
public void resumed() {
|
||||
fireEvent(new DebugEvent(TeaVMDebugTarget.this, DebugEvent.RESUME));
|
||||
}
|
||||
|
||||
@Override
|
||||
public void paused() {
|
||||
fireEvent(new DebugEvent(TeaVMDebugTarget.this, DebugEvent.SUSPEND));
|
||||
}
|
||||
|
||||
@Override
|
||||
public void detached() {
|
||||
fireEvent(new DebugEvent(TeaVMDebugTarget.this, DebugEvent.CHANGE));
|
||||
}
|
||||
|
||||
@Override
|
||||
public void breakpointStatusChanged(Breakpoint breakpoint) {
|
||||
}
|
||||
|
||||
@Override
|
||||
public void attached() {
|
||||
fireEvent(new DebugEvent(TeaVMDebugTarget.this, DebugEvent.CHANGE));
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
private void fireEvent(DebugEvent event) {
|
||||
DebugPlugin.getDefault().fireDebugEventSet(new DebugEvent[] { event });
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean canTerminate() {
|
||||
return true;
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean isTerminated() {
|
||||
return terminated;
|
||||
}
|
||||
|
||||
@Override
|
||||
public void terminate() throws DebugException {
|
||||
terminated = true;
|
||||
server.stop();
|
||||
}
|
||||
|
||||
@Override
|
||||
public Object getAdapter(Class arg0) {
|
||||
return null;
|
||||
}
|
||||
|
||||
@Override
|
||||
public void breakpointAdded(IBreakpoint breakpoint) {
|
||||
if (!(breakpoint instanceof ILineBreakpoint)) {
|
||||
return;
|
||||
}
|
||||
IJavaLineBreakpoint lineBreakpoint = (IJavaLineBreakpoint)breakpoint;
|
||||
try {
|
||||
lineBreakpoint.setRegistered(true);
|
||||
String fileName = lineBreakpoint.getTypeName().replace('.', '/') + ".java";
|
||||
teavmDebugger.createBreakpoint(fileName, lineBreakpoint.getLineNumber());
|
||||
} catch (CoreException e) {
|
||||
throw new RuntimeException(e);
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public void breakpointChanged(IBreakpoint arg0, IMarkerDelta arg1) {
|
||||
}
|
||||
|
||||
@Override
|
||||
public void breakpointRemoved(IBreakpoint arg0, IMarkerDelta arg1) {
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean canResume() {
|
||||
return true;
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean canSuspend() {
|
||||
return true;
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean isSuspended() {
|
||||
return teavmDebugger.isSuspended();
|
||||
}
|
||||
|
||||
@Override
|
||||
public void resume() throws DebugException {
|
||||
teavmDebugger.resume();
|
||||
}
|
||||
|
||||
@Override
|
||||
public void suspend() throws DebugException {
|
||||
teavmDebugger.suspend();
|
||||
}
|
||||
|
||||
@Override
|
||||
public IMemoryBlock getMemoryBlock(long arg0, long arg1) throws DebugException {
|
||||
return null;
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean supportsStorageRetrieval() {
|
||||
return false;
|
||||
}
|
||||
|
||||
@Override
|
||||
public IDebugTarget getDebugTarget() {
|
||||
return this;
|
||||
}
|
||||
|
||||
@Override
|
||||
public ILaunch getLaunch() {
|
||||
return launch;
|
||||
}
|
||||
|
||||
@Override
|
||||
public String getModelIdentifier() {
|
||||
return "";
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean canDisconnect() {
|
||||
return true;
|
||||
}
|
||||
|
||||
@Override
|
||||
public void disconnect() throws DebugException {
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean isDisconnected() {
|
||||
return teavmDebugger.isAttached();
|
||||
}
|
||||
|
||||
@Override
|
||||
public String getName() throws DebugException {
|
||||
return "TeaVM debugger";
|
||||
}
|
||||
|
||||
@Override
|
||||
public IProcess getProcess() {
|
||||
return null;
|
||||
}
|
||||
|
||||
@Override
|
||||
public IThread[] getThreads() throws DebugException {
|
||||
return null;
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean hasThreads() throws DebugException {
|
||||
return false;
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean supportsBreakpoint(IBreakpoint breakpoint) {
|
||||
return breakpoint instanceof IJavaLineBreakpoint;
|
||||
}
|
||||
}
|
|
@ -0,0 +1,85 @@
|
|||
package org.teavm.eclipse.debugger;
|
||||
|
||||
import java.io.IOException;
|
||||
import java.util.ArrayList;
|
||||
import java.util.List;
|
||||
import org.eclipse.core.runtime.CoreException;
|
||||
import org.eclipse.core.runtime.IProgressMonitor;
|
||||
import org.eclipse.debug.core.ILaunch;
|
||||
import org.eclipse.debug.core.ILaunchConfiguration;
|
||||
import org.eclipse.debug.core.ILaunchManager;
|
||||
import org.eclipse.debug.core.model.ILaunchConfigurationDelegate;
|
||||
import org.eclipse.swt.widgets.Display;
|
||||
import org.teavm.chromerdp.*;
|
||||
import org.teavm.debugging.Debugger;
|
||||
import org.teavm.debugging.URLDebugInformationProvider;
|
||||
|
||||
/**
|
||||
*
|
||||
* @author Alexey Andreev <konsoletyper@gmail.com>
|
||||
*/
|
||||
public class TeaVMLaunchConfigurationDelegate implements ILaunchConfigurationDelegate {
|
||||
@Override
|
||||
public void launch(ILaunchConfiguration configuration, String mode, ILaunch launch, IProgressMonitor monitor)
|
||||
throws CoreException {
|
||||
if (!mode.equals(ILaunchManager.DEBUG_MODE)) {
|
||||
throw new IllegalArgumentException("Only debug mode supported");
|
||||
}
|
||||
int port = configuration.getAttribute("teavm-debugger-port", 2357);
|
||||
ChromeRDPServer server = new ChromeRDPServer();
|
||||
server.setPort(port);
|
||||
ChromeRDPDebugger jsDebugger = new ChromeRDPDebugger();
|
||||
server.setExchangeConsumer(new SynchronousMessageExchange(jsDebugger));
|
||||
Debugger debugger = new Debugger(jsDebugger, new URLDebugInformationProvider(""));
|
||||
server.start();
|
||||
launch.addDebugTarget(new TeaVMDebugTarget(launch, debugger, server));
|
||||
monitor.done();
|
||||
}
|
||||
|
||||
private static class SynchronousMessageExchange implements ChromeRDPExchangeConsumer,
|
||||
ChromeRDPExchange {
|
||||
private List<ChromeRDPExchangeListener> listeners = new ArrayList<>();
|
||||
private ChromeRDPDebugger debugger;
|
||||
private ChromeRDPExchange exchange;
|
||||
|
||||
public SynchronousMessageExchange(ChromeRDPDebugger debugger) {
|
||||
this.debugger = debugger;
|
||||
}
|
||||
|
||||
@Override
|
||||
public void setExchange(ChromeRDPExchange exchange) {
|
||||
this.exchange = exchange;
|
||||
debugger.setExchange(this);
|
||||
exchange.addListener(new ChromeRDPExchangeListener() {
|
||||
@Override public void received(final String message) throws IOException {
|
||||
Display.getCurrent().asyncExec(new Runnable() {
|
||||
@Override public void run() {
|
||||
try {
|
||||
for (ChromeRDPExchangeListener listener : listeners) {
|
||||
listener.received(message);
|
||||
}
|
||||
} catch (IOException e) {
|
||||
// TODO: add logging
|
||||
}
|
||||
}
|
||||
});
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
@Override
|
||||
public void send(String message) {
|
||||
exchange.send(message);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void addListener(ChromeRDPExchangeListener listener) {
|
||||
listeners.add(listener);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void removeListener(ChromeRDPExchangeListener listener) {
|
||||
listeners.remove(listener);
|
||||
}
|
||||
}
|
||||
}
|
Loading…
Reference in New Issue
Block a user