aboutsummaryrefslogtreecommitdiffstats
path: root/tests/sourceinfo/JdiTest.java
diff options
context:
space:
mode:
authorwisberg <wisberg>2002-12-16 18:51:06 +0000
committerwisberg <wisberg>2002-12-16 18:51:06 +0000
commit144143c2970a1e874d74cdbd0f8c622d4282a3c3 (patch)
treeb12383d3d9e76c7e1f25f7fbec83051ef17f81fb /tests/sourceinfo/JdiTest.java
parentfafae443719b26159ab2d7dac1c9b46b5e00b671 (diff)
downloadaspectj-144143c2970a1e874d74cdbd0f8c622d4282a3c3.tar.gz
aspectj-144143c2970a1e874d74cdbd0f8c622d4282a3c3.zip
initial version
Diffstat (limited to 'tests/sourceinfo/JdiTest.java')
-rw-r--r--tests/sourceinfo/JdiTest.java145
1 files changed, 145 insertions, 0 deletions
diff --git a/tests/sourceinfo/JdiTest.java b/tests/sourceinfo/JdiTest.java
new file mode 100644
index 000000000..ea56ceb7a
--- /dev/null
+++ b/tests/sourceinfo/JdiTest.java
@@ -0,0 +1,145 @@
+import com.sun.jdi.*;
+import com.sun.jdi.connect.*;
+import com.sun.jdi.request.ClassPrepareRequest;
+import com.sun.jdi.request.EventRequestManager;
+
+import java.util.*;
+import java.io.*;
+
+/**
+ * @version 1.0
+ * @author
+ */
+public class JdiTest {
+ static Thread errThread, outThread;
+
+ public static void main(String[] xxx) throws Exception {
+ LaunchingConnector lc = findLaunchingConnector();
+ String mainArgs = "Hello";
+ Map args = connectorArguments(lc, mainArgs);
+ System.out.println(args);
+ VirtualMachine vm = lc.launch(args);
+ System.out.println(vm);
+ redirectOutput(vm);
+ vm.resume();
+
+ while (vm.classesByName("Hello").size() == 0) {}
+
+
+ ReferenceType rt = (ReferenceType)vm.classesByName("Hello").get(0);
+ System.out.println(rt);
+ System.out.println(rt.availableStrata());
+ try {
+ System.out.println(rt.sourceDebugExtension());
+ System.out.println("Names: " + rt.sourceNames("AspectJ"));
+ } catch (AbsentInformationException aie) {
+ System.out.println("NO source debug extension");
+ }
+ System.out.println("Name: " + rt.sourceName());
+
+
+ for (Iterator i = rt.allLineLocations().iterator(); i.hasNext(); ) {
+ Location loc = (Location)i.next();
+ System.out.println(" " + loc.sourceName() + ":" + loc.lineNumber());
+ }
+
+
+ try {
+ //eventThread.join();
+ errThread.join(); // Make sure output is forwarded
+ outThread.join(); // before we exit
+ } catch (InterruptedException exc) {
+ // we don't interrupt
+ }
+
+ }
+
+ /**
+ * Find a com.sun.jdi.CommandLineLaunch connector
+ */
+ static LaunchingConnector findLaunchingConnector() {
+ List connectors = Bootstrap.virtualMachineManager().allConnectors();
+ Iterator iter = connectors.iterator();
+ while (iter.hasNext()) {
+ Connector connector = (Connector) iter.next();
+ if (connector.name().equals("com.sun.jdi.CommandLineLaunch")) {
+ return (LaunchingConnector) connector;
+ }
+ }
+ throw new Error("No launching connector");
+ }
+
+ /**
+ * Return the launching connector's arguments.
+ */
+ static Map connectorArguments(LaunchingConnector connector, String mainArgs) {
+ Map arguments = connector.defaultArguments();
+ Connector.Argument mainArg = (Connector.Argument) arguments.get("main");
+ if (mainArg == null) {
+ throw new Error("Bad launching connector");
+ }
+ mainArg.setValue(mainArgs);
+
+// if (watchFields) {
+// // We need a VM that supports watchpoints
+// Connector.Argument optionArg = (Connector.Argument) arguments.get("options");
+// if (optionArg == null) {
+// throw new Error("Bad launching connector");
+// }
+// optionArg.setValue("-classic");
+// }
+ return arguments;
+ }
+
+ static void redirectOutput(VirtualMachine vm) {
+ Process process = vm.process();
+
+ // Copy target's output and error to our output and error.
+ errThread = new StreamRedirectThread("error reader",
+ process.getErrorStream(),
+ System.err);
+ outThread = new StreamRedirectThread("output reader",
+ process.getInputStream(),
+ System.out);
+ errThread.start();
+ outThread.start();
+ }
+
+}
+
+class StreamRedirectThread extends Thread {
+
+ private final Reader in;
+ private final Writer out;
+
+ private static final int BUFFER_SIZE = 2048;
+
+ /**
+ * Set up for copy.
+ * @param name Name of the thread
+ * @param in Stream to copy from
+ * @param out Stream to copy to
+ */
+ StreamRedirectThread(String name, InputStream in, OutputStream out) {
+ super(name);
+ this.in = new InputStreamReader(in);
+ this.out = new OutputStreamWriter(out);
+ setPriority(Thread.MAX_PRIORITY-1);
+ }
+
+ /**
+ * Copy.
+ */
+ public void run() {
+ try {
+ char[] cbuf = new char[BUFFER_SIZE];
+ int count;
+ while ((count = in.read(cbuf, 0, BUFFER_SIZE)) >= 0) {
+ out.write(cbuf, 0, count);
+ }
+ out.flush();
+ } catch(IOException exc) {
+ System.err.println("Child I/O Transfer - " + exc);
+ }
+ }
+}