blob: abe3417ca3a84d8223b72aa429b63dfa5b6e9f68 [file] [log] [blame]
<HTML><HEAD><META CONTENT="text/html; charset=UTF-8" HTTP-EQUIV="Content-Type"/><TITLE>EMMA Coverage Report</TITLE><STYLE TYPE="text/css"> TABLE,TD,TH {border-style:solid; border-color:black;} TD,TH {background:white;margin:0;line-height:100%;padding-left:0.5em;padding-right:0.5em;} TD {border-width:0 1px 0 0;} TH {border-width:1px 1px 1px 0;} TR TD.h {color:red;} TABLE {border-spacing:0; border-collapse:collapse;border-width:0 0 1px 1px;} P,H1,H2,H3,TH {font-family:verdana,arial,sans-serif;font-size:10pt;} TD {font-family:courier,monospace;font-size:10pt;} TABLE.hdft {border-spacing:0;border-collapse:collapse;border-style:none;} TABLE.hdft TH,TABLE.hdft TD {border-style:none;line-height:normal;} TABLE.hdft TH.tl,TABLE.hdft TD.tl {background:#6699CC;color:white;} TABLE.hdft TD.nv {background:#6633DD;color:white;} .nv A:link {color:white;} .nv A:visited {color:white;} .nv A:active {color:yellow;} TABLE.hdft A:link {color:white;} TABLE.hdft A:visited {color:white;} TABLE.hdft A:active {color:yellow;} .in {color:#356085;} TABLE.s TD {padding-left:0.25em;padding-right:0.25em;} TABLE.s TD.l {padding-left:0.25em;padding-right:0.25em;text-align:right;background:#F0F0F0;} TABLE.s TR.z TD {background:#FF9999;} TABLE.s TR.p TD {background:#FFFF88;} TABLE.s TR.c TD {background:#CCFFCC;} A:link {color:#0000EE;text-decoration:none;} A:visited {color:#0000EE;text-decoration:none;} A:hover {color:#0000EE;text-decoration:underline;} TABLE.cn {border-width:0 0 1px 0;} TABLE.s {border-width:1px 0 1px 1px;} TD.h {color:red;border-width:0 1px 0 0;} TD.f {border-width:0 1px 0 1px;} TD.hf {color:red;border-width:0 1px 0 1px;} TH.f {border-width:1px 1px 1px 1px;} TR.cis TD {background:#F0F0F0;} TR.cis TD {border-width:1px 1px 1px 0;} TR.cis TD.h {color:red;border-width:1px 1px 1px 0;} TR.cis TD.f {border-width:1px 1px 1px 1px;} TR.cis TD.hf {color:red;border-width:1px 1px 1px 1px;} TD.b {border-style:none;background:transparent;line-height:50%;} TD.bt {border-width:1px 0 0 0;background:transparent;line-height:50%;} TR.o TD {background:#F0F0F0;}TABLE.it {border-style:none;}TABLE.it TD,TABLE.it TH {border-style:none;}</STYLE></HEAD><BODY><TABLE CLASS="hdft" CELLSPACING="0" WIDTH="100%"><TR><TH CLASS="tl"><A HREF="http://www.eclemma.org/">EMMA</A> Coverage Report (generated Fri Feb 20 18:44:54 GMT 2009)</TH></TR><TR><TD CLASS="nv">[<A HREF="../xslUnitTestCoverage.html">all classes</A>][<A HREF="7c.html">org.eclipse.wst.xsl.jaxp.launching.model</A>]</TD></TR></TABLE><H2>COVERAGE SUMMARY FOR SOURCE FILE [<SPAN CLASS="in">JAXPDebugTarget.java</SPAN>]</H2><TABLE CELLSPACING="0" WIDTH="100%"><TR><TH>name</TH><TH>class, %</TH><TH>method, %</TH><TH>block, %</TH><TH>line, %</TH></TR><TR><TD>JAXPDebugTarget.java</TD><TD CLASS="h">50%  (1/2)</TD><TD CLASS="h">12%  (6/52)</TD><TD CLASS="h">10%  (109/1039)</TD><TD CLASS="h">11%  (30/275)</TD></TR></TABLE><H3>COVERAGE BREAKDOWN BY CLASS AND METHOD</H3><TABLE CLASS="cn" CELLSPACING="0" WIDTH="100%"><TR><TH CLASS="f">name</TH><TH>class, %</TH><TH>method, %</TH><TH>block, %</TH><TH>line, %</TH></TR><TR><TD CLASS="b"> </TD><TD CLASS="b"> </TD><TD CLASS="b"> </TD><TD CLASS="b"> </TD><TD CLASS="b"> </TD></TR><TR CLASS="cis"><TD CLASS="f">class <A HREF="#0">JAXPDebugTarget$EventDispatchJob</A></TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/3)</TD><TD CLASS="h">0%   (0/142)</TD><TD CLASS="h">0%   (0/45)</TD></TR><TR><TD CLASS="f"><A HREF="#0">JAXPDebugTarget$EventDispatchJob (JAXPDebugTarget): void</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/10)</TD><TD CLASS="h">0%   (0/3)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#2">debugEventMsg (String): void</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/1)</TD></TR><TR><TD CLASS="f"><A HREF="#3">run (IProgressMonitor): IStatus</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/131)</TD><TD CLASS="h">0%   (0/41)</TD></TR><TR><TD CLASS="bt"> </TD><TD CLASS="bt"> </TD><TD CLASS="bt"> </TD><TD CLASS="bt"> </TD><TD CLASS="bt"> </TD></TR><TR CLASS="cis"><TD CLASS="f">class <A HREF="#4">JAXPDebugTarget</A></TD><TD>100% (1/1)</TD><TD CLASS="h">12%  (6/49)</TD><TD CLASS="h">12%  (109/897)</TD><TD CLASS="h">13%  (30/230)</TD></TR><TR><TD CLASS="f"><A HREF="#5">abort (String, Throwable): void</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/20)</TD><TD CLASS="h">0%   (0/5)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#6">access$0 (JAXPDebugTarget): BufferedReader</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/3)</TD><TD CLASS="h">0%   (0/1)</TD></TR><TR><TD CLASS="f"><A HREF="#4">access$1 (JAXPDebugTarget): XSLThread</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/3)</TD><TD CLASS="h">0%   (0/1)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#8">access$2 (JAXPDebugTarget): void</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/3)</TD><TD CLASS="h">0%   (0/1)</TD></TR><TR><TD CLASS="f"><A HREF="#9">access$3 (JAXPDebugTarget): void</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/3)</TD><TD CLASS="h">0%   (0/1)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#a">access$4 (JAXPDebugTarget, int): void</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/4)</TD><TD CLASS="h">0%   (0/1)</TD></TR><TR><TD CLASS="f"><A HREF="#b">access$5 (JAXPDebugTarget): void</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/3)</TD><TD CLASS="h">0%   (0/1)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#c">access$6 (JAXPDebugTarget, int): void</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/4)</TD><TD CLASS="h">0%   (0/1)</TD></TR><TR><TD CLASS="f"><A HREF="#d">access$7 (JAXPDebugTarget, String): void</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/4)</TD><TD CLASS="h">0%   (0/1)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#e">breakpointAdded (IBreakpoint): void</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/48)</TD><TD CLASS="h">0%   (0/15)</TD></TR><TR><TD CLASS="f"><A HREF="#f">breakpointChanged (IBreakpoint, IMarkerDelta): void</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/18)</TD><TD CLASS="h">0%   (0/6)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#10">breakpointHit (String): void</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/65)</TD><TD CLASS="h">0%   (0/18)</TD></TR><TR><TD CLASS="f"><A HREF="#11">breakpointRemoved (IBreakpoint, IMarkerDelta): void</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/43)</TD><TD CLASS="h">0%   (0/13)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#12">canResume (): boolean</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/10)</TD><TD CLASS="h">0%   (0/1)</TD></TR><TR><TD CLASS="f"><A HREF="#13">canSuspend (): boolean</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/10)</TD><TD CLASS="h">0%   (0/1)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#14">disconnect (): void</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/1)</TD></TR><TR><TD CLASS="f"><A HREF="#15">getDebugTarget (): IDebugTarget</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/2)</TD><TD CLASS="h">0%   (0/1)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#16">getGenerateReader (): Reader</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/3)</TD><TD CLASS="h">0%   (0/1)</TD></TR><TR><TD CLASS="f"><A HREF="#17">getLaunch (): ILaunch</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/3)</TD><TD CLASS="h">0%   (0/1)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#18">getMemoryBlock (long, long): IMemoryBlock</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/2)</TD><TD CLASS="h">0%   (0/1)</TD></TR><TR><TD CLASS="f"><A HREF="#19">getName (): String</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/12)</TD><TD CLASS="h">0%   (0/3)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#1a">getStackFrames (): IStackFrame []</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/89)</TD><TD CLASS="h">0%   (0/20)</TD></TR><TR><TD CLASS="f"><A HREF="#1b">getThreads (): IThread []</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/3)</TD><TD CLASS="h">0%   (0/1)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#1c">getVariable (int): XSLVariable</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/58)</TD><TD CLASS="h">0%   (0/11)</TD></TR><TR><TD CLASS="f"><A HREF="#1d">getVariableValue (XSLVariable): IValue</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/74)</TD><TD CLASS="h">0%   (0/15)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#1e">hasThreads (): boolean</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/11)</TD><TD CLASS="h">0%   (0/1)</TD></TR><TR><TD CLASS="f"><A HREF="#1f">installDeferredBreakpoints (): void</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/25)</TD><TD CLASS="h">0%   (0/6)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#20">isDisconnected (): boolean</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/2)</TD><TD CLASS="h">0%   (0/1)</TD></TR><TR><TD CLASS="f"><A HREF="#21">isSuspended (): boolean</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/3)</TD><TD CLASS="h">0%   (0/1)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#22">ready (): void</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/13)</TD><TD CLASS="h">0%   (0/6)</TD></TR><TR><TD CLASS="f"><A HREF="#23">ressetStackFramesCache (): void</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/18)</TD><TD CLASS="h">0%   (0/4)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#24">resume (): void</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/5)</TD><TD CLASS="h">0%   (0/2)</TD></TR><TR><TD CLASS="f"><A HREF="#25">resumed (int): void</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/8)</TD><TD CLASS="h">0%   (0/3)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#26">sendRequest (String): String</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/39)</TD><TD CLASS="h">0%   (0/8)</TD></TR><TR><TD CLASS="f"><A HREF="#27">stepInto (): void</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/5)</TD><TD CLASS="h">0%   (0/2)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#28">stepOver (): void</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/5)</TD><TD CLASS="h">0%   (0/2)</TD></TR><TR><TD CLASS="f"><A HREF="#29">stepReturn (): void</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/5)</TD><TD CLASS="h">0%   (0/2)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#2a">supportsBreakpoint (IBreakpoint): boolean</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/12)</TD><TD CLASS="h">0%   (0/5)</TD></TR><TR><TD CLASS="f"><A HREF="#2b">supportsStorageRetrieval (): boolean</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/2)</TD><TD CLASS="h">0%   (0/1)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#2c">suspend (): void</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/5)</TD><TD CLASS="h">0%   (0/2)</TD></TR><TR><TD CLASS="f"><A HREF="#2d">suspended (int): void</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/8)</TD><TD CLASS="h">0%   (0/3)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#2e">terminate (): void</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/15)</TD><TD CLASS="h">0%   (0/3)</TD></TR><TR><TD CLASS="f"><A HREF="#2f">terminated (): void</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/14)</TD><TD CLASS="h">0%   (0/5)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#30">attemptConnect (int): Socket</A></TD><TD> </TD><TD>100% (1/1)</TD><TD CLASS="h">47%  (29/62)</TD><TD CLASS="h">47%  (9/19)</TD></TR><TR><TD CLASS="f"><A HREF="#31">JAXPDebugTarget (ILaunch, IProcess, BaseLaunchHelper): void</A></TD><TD> </TD><TD>100% (1/1)</TD><TD CLASS="h">48%  (67/139)</TD><TD CLASS="h">61%  (17/28)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#32">canDisconnect (): boolean</A></TD><TD> </TD><TD>100% (1/1)</TD><TD>100% (2/2)</TD><TD>100% (1/1)</TD></TR><TR><TD CLASS="f"><A HREF="#33">canTerminate (): boolean</A></TD><TD> </TD><TD>100% (1/1)</TD><TD>100% (4/4)</TD><TD>100% (1/1)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#34">getProcess (): IProcess</A></TD><TD> </TD><TD>100% (1/1)</TD><TD>100% (3/3)</TD><TD>100% (1/1)</TD></TR><TR><TD CLASS="f"><A HREF="#35">isTerminated (): boolean</A></TD><TD> </TD><TD>100% (1/1)</TD><TD>100% (4/4)</TD><TD>100% (1/1)</TD></TR></TABLE><P></P><TABLE CLASS="s" CELLSPACING="0" WIDTH="100%"><TR><TD CLASS="l">1</TD><TD>/*******************************************************************************</TD></TR><TR><TD CLASS="l">2</TD><TD> * Copyright (c) 2007 Chase Technology Ltd - http://www.chasetechnology.co.uk</TD></TR><TR><TD CLASS="l">3</TD><TD> * All rights reserved. This program and the accompanying materials</TD></TR><TR><TD CLASS="l">4</TD><TD> * are made available under the terms of the Eclipse Public License v1.0</TD></TR><TR><TD CLASS="l">5</TD><TD> * which accompanies this distribution, and is available at</TD></TR><TR><TD CLASS="l">6</TD><TD> * http://www.eclipse.org/legal/epl-v10.html</TD></TR><TR><TD CLASS="l">7</TD><TD> *</TD></TR><TR><TD CLASS="l">8</TD><TD> * Contributors:</TD></TR><TR><TD CLASS="l">9</TD><TD> *     Doug Satchwell (Chase Technology Ltd) - initial API and implementation</TD></TR><TR><TD CLASS="l">10</TD><TD> *******************************************************************************/</TD></TR><TR><TD CLASS="l">11</TD><TD>package org.eclipse.wst.xsl.jaxp.launching.model;</TD></TR><TR><TD CLASS="l">12</TD><TD> </TD></TR><TR><TD CLASS="l">13</TD><TD>import java.io.BufferedReader;</TD></TR><TR><TD CLASS="l">14</TD><TD>import java.io.IOException;</TD></TR><TR><TD CLASS="l">15</TD><TD>import java.io.InputStreamReader;</TD></TR><TR><TD CLASS="l">16</TD><TD>import java.io.PrintWriter;</TD></TR><TR><TD CLASS="l">17</TD><TD>import java.io.Reader;</TD></TR><TR><TD CLASS="l">18</TD><TD>import java.net.ConnectException;</TD></TR><TR><TD CLASS="l">19</TD><TD>import java.net.MalformedURLException;</TD></TR><TR><TD CLASS="l">20</TD><TD>import java.net.Socket;</TD></TR><TR><TD CLASS="l">21</TD><TD>import java.net.URL;</TD></TR><TR><TD CLASS="l">22</TD><TD>import java.util.Arrays;</TD></TR><TR><TD CLASS="l">23</TD><TD>import java.util.HashMap;</TD></TR><TR><TD CLASS="l">24</TD><TD>import java.util.List;</TD></TR><TR><TD CLASS="l">25</TD><TD>import java.util.Map;</TD></TR><TR><TD CLASS="l">26</TD><TD> </TD></TR><TR><TD CLASS="l">27</TD><TD>import org.eclipse.core.resources.IMarker;</TD></TR><TR><TD CLASS="l">28</TD><TD>import org.eclipse.core.resources.IMarkerDelta;</TD></TR><TR><TD CLASS="l">29</TD><TD>import org.eclipse.core.runtime.CoreException;</TD></TR><TR><TD CLASS="l">30</TD><TD>import org.eclipse.core.runtime.IProgressMonitor;</TD></TR><TR><TD CLASS="l">31</TD><TD>import org.eclipse.core.runtime.IStatus;</TD></TR><TR><TD CLASS="l">32</TD><TD>import org.eclipse.core.runtime.Status;</TD></TR><TR><TD CLASS="l">33</TD><TD>import org.eclipse.core.runtime.jobs.Job;</TD></TR><TR><TD CLASS="l">34</TD><TD>import org.eclipse.debug.core.DebugEvent;</TD></TR><TR><TD CLASS="l">35</TD><TD>import org.eclipse.debug.core.DebugException;</TD></TR><TR><TD CLASS="l">36</TD><TD>import org.eclipse.debug.core.DebugPlugin;</TD></TR><TR><TD CLASS="l">37</TD><TD>import org.eclipse.debug.core.ILaunch;</TD></TR><TR><TD CLASS="l">38</TD><TD>import org.eclipse.debug.core.model.IBreakpoint;</TD></TR><TR><TD CLASS="l">39</TD><TD>import org.eclipse.debug.core.model.IDebugTarget;</TD></TR><TR><TD CLASS="l">40</TD><TD>import org.eclipse.debug.core.model.ILineBreakpoint;</TD></TR><TR><TD CLASS="l">41</TD><TD>import org.eclipse.debug.core.model.IMemoryBlock;</TD></TR><TR><TD CLASS="l">42</TD><TD>import org.eclipse.debug.core.model.IProcess;</TD></TR><TR><TD CLASS="l">43</TD><TD>import org.eclipse.debug.core.model.IStackFrame;</TD></TR><TR><TD CLASS="l">44</TD><TD>import org.eclipse.debug.core.model.IThread;</TD></TR><TR><TD CLASS="l">45</TD><TD>import org.eclipse.debug.core.model.IValue;</TD></TR><TR><TD CLASS="l">46</TD><TD>import org.eclipse.wst.xsl.jaxp.debug.debugger.DebugConstants;</TD></TR><TR><TD CLASS="l">47</TD><TD>import org.eclipse.wst.xsl.jaxp.launching.Messages;</TD></TR><TR><TD CLASS="l">48</TD><TD>import org.eclipse.wst.xsl.jaxp.launching.internal.JAXPLaunchingPlugin;</TD></TR><TR><TD CLASS="l">49</TD><TD>import org.eclipse.wst.xsl.launching.config.BaseLaunchHelper;</TD></TR><TR><TD CLASS="l">50</TD><TD>import org.eclipse.wst.xsl.launching.model.IXSLConstants;</TD></TR><TR><TD CLASS="l">51</TD><TD>import org.eclipse.wst.xsl.launching.model.IXSLDebugTarget;</TD></TR><TR><TD CLASS="l">52</TD><TD>import org.eclipse.wst.xsl.launching.model.XSLDebugElement;</TD></TR><TR><TD CLASS="l">53</TD><TD>import org.eclipse.wst.xsl.launching.model.XSLStackFrame;</TD></TR><TR><TD CLASS="l">54</TD><TD>import org.eclipse.wst.xsl.launching.model.XSLThread;</TD></TR><TR><TD CLASS="l">55</TD><TD>import org.eclipse.wst.xsl.launching.model.XSLValue;</TD></TR><TR><TD CLASS="l">56</TD><TD>import org.eclipse.wst.xsl.launching.model.XSLVariable;</TD></TR><TR><TD CLASS="l">57</TD><TD> </TD></TR><TR><TD CLASS="l">58</TD><TD>public class JAXPDebugTarget extends XSLDebugElement implements IXSLDebugTarget {</TD></TR><TR CLASS="c"><TD CLASS="l">59</TD><TD>        private final byte[] STACK_FRAMES_LOCK = new byte[0];</TD></TR><TR CLASS="c"><TD CLASS="l">60</TD><TD>        private final byte[] VALUE_MAP_LOCK = new byte[0];</TD></TR><TR CLASS="c"><TD CLASS="l">61</TD><TD>        private final byte[] WRITE_LOCK = new byte[0];</TD></TR><TR><TD CLASS="l">62</TD><TD> </TD></TR><TR CLASS="c"><TD CLASS="l">63</TD><TD>        private final int CONNECT_ATTEMPTS = 60;</TD></TR><TR CLASS="c"><TD CLASS="l"><A NAME="4">64</A></TD><TD>        private final int CONNECT_WAIT = 1000;</TD></TR><TR><TD CLASS="l">65</TD><TD> </TD></TR><TR><TD CLASS="l">66</TD><TD>        private final IProcess process;</TD></TR><TR><TD CLASS="l">67</TD><TD>        private final ILaunch launch;</TD></TR><TR CLASS="z"><TD CLASS="l">68</TD><TD>        private XSLThread thread;</TD></TR><TR CLASS="c"><TD CLASS="l">69</TD><TD>        private IThread[] threads = new IThread[0];</TD></TR><TR CLASS="c"><TD CLASS="l">70</TD><TD>        private IStackFrame[] stackFramesCache = new IStackFrame[0];</TD></TR><TR><TD CLASS="l">71</TD><TD> </TD></TR><TR><TD CLASS="l">72</TD><TD>        private EventDispatchJob eventDispatch;</TD></TR><TR><TD CLASS="l">73</TD><TD> </TD></TR><TR CLASS="c"><TD CLASS="l">74</TD><TD>        private final Map&lt;Integer, XSLVariable&gt; variableMapCache = new HashMap&lt;Integer, XSLVariable&gt;();</TD></TR><TR CLASS="c"><TD CLASS="l">75</TD><TD>        private final Map&lt;XSLVariable, XSLValue&gt; valueMapCache = new HashMap&lt;XSLVariable, XSLValue&gt;();</TD></TR><TR><TD CLASS="l">76</TD><TD>        private String name;</TD></TR><TR><TD CLASS="l">77</TD><TD>        private boolean suspended;</TD></TR><TR><TD CLASS="l">78</TD><TD> </TD></TR><TR><TD CLASS="l"><A NAME="6">79</A></TD><TD>        private Socket requestSocket;</TD></TR><TR><TD CLASS="l">80</TD><TD>        private Socket eventSocket;</TD></TR><TR><TD CLASS="l">81</TD><TD>        private Socket generateSocket;</TD></TR><TR><TD CLASS="l">82</TD><TD>        private BufferedReader requestReader;</TD></TR><TR CLASS="z"><TD CLASS="l">83</TD><TD>        private BufferedReader eventReader;</TD></TR><TR><TD CLASS="l">84</TD><TD>        private PrintWriter requestWriter;</TD></TR><TR><TD CLASS="l">85</TD><TD>        private Reader generateReader;</TD></TR><TR><TD CLASS="l"><A NAME="31">86</A></TD><TD>        private boolean stale;</TD></TR><TR><TD CLASS="l">87</TD><TD> </TD></TR><TR><TD CLASS="l">88</TD><TD>        public JAXPDebugTarget(ILaunch launch, IProcess process,</TD></TR><TR><TD CLASS="l">89</TD><TD>                        BaseLaunchHelper BaseLaunchHelper) throws CoreException {</TD></TR><TR CLASS="c"><TD CLASS="l">90</TD><TD>                super(null);</TD></TR><TR CLASS="c"><TD CLASS="l">91</TD><TD>                this.launch = launch;</TD></TR><TR CLASS="c"><TD CLASS="l">92</TD><TD>                this.process = process;</TD></TR><TR CLASS="c"><TD CLASS="l">93</TD><TD>                this.requestSocket = attemptConnect(BaseLaunchHelper.getRequestPort());</TD></TR><TR CLASS="c"><TD CLASS="l">94</TD><TD>                this.eventSocket = attemptConnect(BaseLaunchHelper.getEventPort());</TD></TR><TR CLASS="c"><TD CLASS="l">95</TD><TD>                this.generateSocket = attemptConnect(BaseLaunchHelper.getGeneratePort());</TD></TR><TR><TD CLASS="l">96</TD><TD> </TD></TR><TR CLASS="c"><TD CLASS="l">97</TD><TD>                if (!process.isTerminated()) {</TD></TR><TR><TD CLASS="l">98</TD><TD>                        try {</TD></TR><TR CLASS="z"><TD CLASS="l">99</TD><TD>                                this.eventReader = new BufferedReader(new InputStreamReader(eventSocket.getInputStream()));</TD></TR><TR CLASS="z"><TD CLASS="l">100</TD><TD>                                this.requestWriter = new PrintWriter(requestSocket.getOutputStream());</TD></TR><TR CLASS="z"><TD CLASS="l">101</TD><TD>                                this.requestReader = new BufferedReader(new InputStreamReader(requestSocket.getInputStream()));</TD></TR><TR CLASS="z"><TD CLASS="l">102</TD><TD>                                this.generateReader = new InputStreamReader(generateSocket.getInputStream());</TD></TR><TR CLASS="z"><TD CLASS="l">103</TD><TD>                        } catch (IOException e) {</TD></TR><TR CLASS="z"><TD CLASS="l">104</TD><TD>                                abort(Messages.XSLDebugTarget_0, e); </TD></TR><TR><TD CLASS="l">105</TD><TD>                        }</TD></TR><TR CLASS="z"><TD CLASS="l">106</TD><TD>                        this.thread = new XSLThread(this);</TD></TR><TR CLASS="z"><TD CLASS="l">107</TD><TD>                        this.threads = new IThread[] { thread };</TD></TR><TR CLASS="z"><TD CLASS="l">108</TD><TD>                        this.eventDispatch = new EventDispatchJob();</TD></TR><TR CLASS="z"><TD CLASS="l">109</TD><TD>                        this.eventDispatch.schedule();</TD></TR><TR><TD CLASS="l">110</TD><TD>                        </TD></TR><TR CLASS="z"><TD CLASS="l">111</TD><TD>                        DebugPlugin.getDefault().getBreakpointManager().addBreakpointListener(this);</TD></TR><TR><TD CLASS="l">112</TD><TD>                }</TD></TR><TR CLASS="c"><TD CLASS="l"><A NAME="16">113</A></TD><TD>        }</TD></TR><TR><TD CLASS="l">114</TD><TD>        </TD></TR><TR><TD CLASS="l">115</TD><TD>        public Reader getGenerateReader()</TD></TR><TR><TD CLASS="l">116</TD><TD>        {</TD></TR><TR CLASS="z"><TD CLASS="l"><A NAME="5">117</A></TD><TD>                return generateReader;</TD></TR><TR><TD CLASS="l">118</TD><TD>        }</TD></TR><TR><TD CLASS="l">119</TD><TD> </TD></TR><TR><TD CLASS="l">120</TD><TD>        private void abort(String message, Throwable e) throws DebugException {</TD></TR><TR CLASS="z"><TD CLASS="l">121</TD><TD>                if (!getDebugTarget().isTerminated())</TD></TR><TR CLASS="z"><TD CLASS="l">122</TD><TD>                        getDebugTarget().getProcess().terminate();</TD></TR><TR CLASS="z"><TD CLASS="l">123</TD><TD>                throw new DebugException(new Status(IStatus.ERROR,</TD></TR><TR CLASS="z"><TD CLASS="l">124</TD><TD>                                JAXPLaunchingPlugin.PLUGIN_ID, DebugPlugin.INTERNAL_ERROR, message,</TD></TR><TR CLASS="z"><TD CLASS="l"><A NAME="30">125</A></TD><TD>                                e));</TD></TR><TR><TD CLASS="l">126</TD><TD>        }</TD></TR><TR><TD CLASS="l">127</TD><TD> </TD></TR><TR><TD CLASS="l">128</TD><TD>        private Socket attemptConnect(int port) throws CoreException {</TD></TR><TR CLASS="c"><TD CLASS="l">129</TD><TD>                Socket socket = null;</TD></TR><TR CLASS="c"><TD CLASS="l">130</TD><TD>                for (int i = 0; i &lt; CONNECT_ATTEMPTS; i++) {</TD></TR><TR><TD CLASS="l">131</TD><TD>                        // break out if process is terminated</TD></TR><TR CLASS="c"><TD CLASS="l">132</TD><TD>                        if (process.isTerminated())</TD></TR><TR CLASS="c"><TD CLASS="l">133</TD><TD>                                break;</TD></TR><TR><TD CLASS="l">134</TD><TD>                        try {</TD></TR><TR CLASS="z"><TD CLASS="l">135</TD><TD>                                socket = new Socket(</TD></TR><TR CLASS="z"><TD CLASS="l">136</TD><TD>                                                Messages.XSLDebugTarget_1, port); </TD></TR><TR CLASS="c"><TD CLASS="l">137</TD><TD>                        } catch (ConnectException e) {</TD></TR><TR CLASS="z"><TD CLASS="l">138</TD><TD>                        } catch (IOException e) {</TD></TR><TR><TD CLASS="l">139</TD><TD>                        }</TD></TR><TR CLASS="c"><TD CLASS="l">140</TD><TD>                        if (socket != null)</TD></TR><TR CLASS="z"><TD CLASS="l">141</TD><TD>                                break;</TD></TR><TR><TD CLASS="l">142</TD><TD>                        try {</TD></TR><TR CLASS="c"><TD CLASS="l">143</TD><TD>                                Thread.sleep(CONNECT_WAIT);</TD></TR><TR CLASS="z"><TD CLASS="l">144</TD><TD>                        } catch (InterruptedException e) {</TD></TR><TR><TD CLASS="l">145</TD><TD>                        }</TD></TR><TR><TD CLASS="l">146</TD><TD>                }</TD></TR><TR CLASS="c"><TD CLASS="l">147</TD><TD>                if (socket == null &amp;&amp; !process.isTerminated())</TD></TR><TR CLASS="z"><TD CLASS="l">148</TD><TD>                        throw new CoreException(</TD></TR><TR CLASS="z"><TD CLASS="l">149</TD><TD>                                        new Status(</TD></TR><TR CLASS="z"><TD CLASS="l">150</TD><TD>                                                        IStatus.ERROR,</TD></TR><TR CLASS="z"><TD CLASS="l">151</TD><TD>                                                        JAXPLaunchingPlugin.PLUGIN_ID,</TD></TR><TR CLASS="z"><TD CLASS="l">152</TD><TD>                                                        Messages.XSLDebugTarget_2 + port + Messages.XSLDebugTarget_3 + CONNECT_ATTEMPTS + Messages.XSLDebugTarget_4)); </TD></TR><TR CLASS="c"><TD CLASS="l"><A NAME="34">153</A></TD><TD>                return socket;</TD></TR><TR><TD CLASS="l">154</TD><TD>        }</TD></TR><TR><TD CLASS="l">155</TD><TD> </TD></TR><TR><TD CLASS="l">156</TD><TD>        public IProcess getProcess() {</TD></TR><TR CLASS="c"><TD CLASS="l"><A NAME="1b">157</A></TD><TD>                return process;</TD></TR><TR><TD CLASS="l">158</TD><TD>        }</TD></TR><TR><TD CLASS="l">159</TD><TD> </TD></TR><TR><TD CLASS="l">160</TD><TD>        public IThread[] getThreads() throws DebugException {</TD></TR><TR CLASS="z"><TD CLASS="l"><A NAME="1e">161</A></TD><TD>                return threads;</TD></TR><TR><TD CLASS="l">162</TD><TD>        }</TD></TR><TR><TD CLASS="l">163</TD><TD> </TD></TR><TR><TD CLASS="l">164</TD><TD>        public boolean hasThreads() throws DebugException {</TD></TR><TR CLASS="z"><TD CLASS="l"><A NAME="19">165</A></TD><TD>                return threads != null &amp;&amp; threads.length &gt; 0;</TD></TR><TR><TD CLASS="l">166</TD><TD>        }</TD></TR><TR><TD CLASS="l">167</TD><TD> </TD></TR><TR><TD CLASS="l">168</TD><TD>        public String getName() throws DebugException {</TD></TR><TR CLASS="z"><TD CLASS="l">169</TD><TD>                if (name == null) {</TD></TR><TR CLASS="z"><TD CLASS="l">170</TD><TD>                        name = launch.getAttribute(&#34;launchName&#34;);</TD></TR><TR><TD CLASS="l">171</TD><TD>                }</TD></TR><TR CLASS="z"><TD CLASS="l"><A NAME="2a">172</A></TD><TD>                return name;</TD></TR><TR><TD CLASS="l">173</TD><TD>        }</TD></TR><TR><TD CLASS="l">174</TD><TD> </TD></TR><TR><TD CLASS="l">175</TD><TD>        public boolean supportsBreakpoint(IBreakpoint breakpoint) {</TD></TR><TR CLASS="z"><TD CLASS="l">176</TD><TD>                if (breakpoint.getModelIdentifier().equals(</TD></TR><TR CLASS="z"><TD CLASS="l">177</TD><TD>                                IXSLConstants.ID_XSL_DEBUG_MODEL)</TD></TR><TR CLASS="z"><TD CLASS="l">178</TD><TD>                                &amp;&amp; breakpoint instanceof ILineBreakpoint) {</TD></TR><TR><TD CLASS="l">179</TD><TD>                        // try</TD></TR><TR><TD CLASS="l">180</TD><TD>                        // {</TD></TR><TR><TD CLASS="l">181</TD><TD>                        // ILineBreakpoint lb = (ILineBreakpoint) breakpoint;</TD></TR><TR><TD CLASS="l">182</TD><TD>                        // IMarker marker = lb.getMarker();</TD></TR><TR><TD CLASS="l">183</TD><TD>                        // for (Iterator&lt;?&gt; iter =</TD></TR><TR><TD CLASS="l">184</TD><TD>                        // BaseLaunchHelper.getPipeline().getTransformDefs().iterator();</TD></TR><TR><TD CLASS="l">185</TD><TD>                        // iter.hasNext();)</TD></TR><TR><TD CLASS="l">186</TD><TD>                        // {</TD></TR><TR><TD CLASS="l">187</TD><TD>                        // LaunchTransform lt = (LaunchTransform) iter.next();</TD></TR><TR><TD CLASS="l">188</TD><TD>                        // if (marker.getResource().getLocation().equals(lt.getLocation()))</TD></TR><TR><TD CLASS="l">189</TD><TD>                        // return true;</TD></TR><TR><TD CLASS="l">190</TD><TD>                        // }</TD></TR><TR><TD CLASS="l">191</TD><TD>                        // }</TD></TR><TR><TD CLASS="l">192</TD><TD>                        // catch (CoreException e)</TD></TR><TR><TD CLASS="l">193</TD><TD>                        // {</TD></TR><TR><TD CLASS="l">194</TD><TD>                        // JAXPLaunchingPlugin.log(e);</TD></TR><TR><TD CLASS="l">195</TD><TD>                        // }</TD></TR><TR CLASS="z"><TD CLASS="l">196</TD><TD>                        return true;</TD></TR><TR><TD CLASS="l">197</TD><TD>                }</TD></TR><TR CLASS="z"><TD CLASS="l">198</TD><TD>                return false;</TD></TR><TR><TD CLASS="l"><A NAME="15">199</A></TD><TD>        }</TD></TR><TR><TD CLASS="l">200</TD><TD> </TD></TR><TR><TD CLASS="l">201</TD><TD>        @Override</TD></TR><TR><TD CLASS="l">202</TD><TD>        public IDebugTarget getDebugTarget() {</TD></TR><TR CLASS="z"><TD CLASS="l">203</TD><TD>                return this;</TD></TR><TR><TD CLASS="l"><A NAME="17">204</A></TD><TD>        }</TD></TR><TR><TD CLASS="l">205</TD><TD> </TD></TR><TR><TD CLASS="l">206</TD><TD>        @Override</TD></TR><TR><TD CLASS="l">207</TD><TD>        public ILaunch getLaunch() {</TD></TR><TR CLASS="z"><TD CLASS="l"><A NAME="33">208</A></TD><TD>                return launch;</TD></TR><TR><TD CLASS="l">209</TD><TD>        }</TD></TR><TR><TD CLASS="l">210</TD><TD> </TD></TR><TR><TD CLASS="l">211</TD><TD>        public boolean canTerminate() {</TD></TR><TR CLASS="c"><TD CLASS="l"><A NAME="35">212</A></TD><TD>                return getProcess().canTerminate();</TD></TR><TR><TD CLASS="l">213</TD><TD>        }</TD></TR><TR><TD CLASS="l">214</TD><TD> </TD></TR><TR><TD CLASS="l">215</TD><TD>        public boolean isTerminated() {</TD></TR><TR CLASS="c"><TD CLASS="l"><A NAME="2e">216</A></TD><TD>                return getProcess().isTerminated();</TD></TR><TR><TD CLASS="l">217</TD><TD>        }</TD></TR><TR><TD CLASS="l">218</TD><TD> </TD></TR><TR><TD CLASS="l">219</TD><TD>        public void terminate() throws DebugException {</TD></TR><TR CLASS="z"><TD CLASS="l">220</TD><TD>                synchronized (WRITE_LOCK) {</TD></TR><TR CLASS="z"><TD CLASS="l">221</TD><TD>                        getProcess().terminate();</TD></TR><TR><TD CLASS="l"><A NAME="12">222</A></TD><TD>                }</TD></TR><TR CLASS="z"><TD CLASS="l">223</TD><TD>        }</TD></TR><TR><TD CLASS="l">224</TD><TD> </TD></TR><TR><TD CLASS="l">225</TD><TD>        public boolean canResume() {</TD></TR><TR CLASS="z"><TD CLASS="l"><A NAME="13">226</A></TD><TD>                return !isTerminated() &amp;&amp; isSuspended();</TD></TR><TR><TD CLASS="l">227</TD><TD>        }</TD></TR><TR><TD CLASS="l">228</TD><TD> </TD></TR><TR><TD CLASS="l">229</TD><TD>        public boolean canSuspend() {</TD></TR><TR CLASS="z"><TD CLASS="l"><A NAME="21">230</A></TD><TD>                return !isTerminated() &amp;&amp; !isSuspended();</TD></TR><TR><TD CLASS="l">231</TD><TD>        }</TD></TR><TR><TD CLASS="l">232</TD><TD> </TD></TR><TR><TD CLASS="l">233</TD><TD>        public boolean isSuspended() {</TD></TR><TR CLASS="z"><TD CLASS="l"><A NAME="24">234</A></TD><TD>                return suspended;</TD></TR><TR><TD CLASS="l">235</TD><TD>        }</TD></TR><TR><TD CLASS="l">236</TD><TD> </TD></TR><TR><TD CLASS="l"><A NAME="a">237</A></TD><TD>        public void resume() throws DebugException {</TD></TR><TR CLASS="z"><TD CLASS="l"><A NAME="25">238</A></TD><TD>                sendRequest(DebugConstants.REQUEST_RESUME);</TD></TR><TR CLASS="z"><TD CLASS="l">239</TD><TD>        }</TD></TR><TR><TD CLASS="l">240</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">241</TD><TD>        private void resumed(int detail) {</TD></TR><TR CLASS="z"><TD CLASS="l"><A NAME="c">242</A></TD><TD>                suspended = false;</TD></TR><TR CLASS="z"><TD CLASS="l"><A NAME="2d">243</A></TD><TD>                thread.fireResumeEvent(detail);</TD></TR><TR CLASS="z"><TD CLASS="l">244</TD><TD>        }</TD></TR><TR><TD CLASS="l">245</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">246</TD><TD>        private void suspended(int detail) {</TD></TR><TR CLASS="z"><TD CLASS="l">247</TD><TD>                suspended = true;</TD></TR><TR CLASS="z"><TD CLASS="l"><A NAME="2c">248</A></TD><TD>                thread.fireSuspendEvent(detail);</TD></TR><TR CLASS="z"><TD CLASS="l">249</TD><TD>        }</TD></TR><TR><TD CLASS="l">250</TD><TD> </TD></TR><TR><TD CLASS="l">251</TD><TD>        public void suspend() throws DebugException {</TD></TR><TR CLASS="z"><TD CLASS="l"><A NAME="e">252</A></TD><TD>                sendRequest(DebugConstants.REQUEST_SUSPEND);</TD></TR><TR CLASS="z"><TD CLASS="l">253</TD><TD>        }</TD></TR><TR><TD CLASS="l">254</TD><TD> </TD></TR><TR><TD CLASS="l">255</TD><TD>        public void breakpointAdded(IBreakpoint breakpoint) {</TD></TR><TR CLASS="z"><TD CLASS="l">256</TD><TD>                if (supportsBreakpoint(breakpoint)) {</TD></TR><TR><TD CLASS="l">257</TD><TD>                        try {</TD></TR><TR CLASS="z"><TD CLASS="l">258</TD><TD>                                ILineBreakpoint lb = (ILineBreakpoint) breakpoint;</TD></TR><TR CLASS="z"><TD CLASS="l">259</TD><TD>                                if (breakpoint.isEnabled()) {</TD></TR><TR><TD CLASS="l">260</TD><TD>                                        try {</TD></TR><TR CLASS="z"><TD CLASS="l">261</TD><TD>                                                IMarker marker = lb.getMarker();</TD></TR><TR CLASS="z"><TD CLASS="l">262</TD><TD>                                                if (marker != null) {</TD></TR><TR CLASS="z"><TD CLASS="l">263</TD><TD>                                                        URL file = marker.getResource().getLocation()</TD></TR><TR CLASS="z"><TD CLASS="l">264</TD><TD>                                                                        .toFile().toURI().toURL();</TD></TR><TR CLASS="z"><TD CLASS="l">265</TD><TD>                                                        sendRequest(DebugConstants.REQUEST_ADD_BREAKPOINT</TD></TR><TR CLASS="z"><TD CLASS="l">266</TD><TD>                                                                        + &#34; &#34; + file + &#34; &#34; + lb.getLineNumber()); //$NON-NLS-1$ //$NON-NLS-2$</TD></TR><TR><TD CLASS="l">267</TD><TD>                                                }</TD></TR><TR CLASS="z"><TD CLASS="l">268</TD><TD>                                        } catch (CoreException e) {</TD></TR><TR CLASS="z"><TD CLASS="l">269</TD><TD>                                                JAXPLaunchingPlugin.log(e);</TD></TR><TR CLASS="z"><TD CLASS="l">270</TD><TD>                                        } catch (MalformedURLException e) {</TD></TR><TR CLASS="z"><TD CLASS="l">271</TD><TD>                                                JAXPLaunchingPlugin.log(e);</TD></TR><TR><TD CLASS="l">272</TD><TD>                                        }</TD></TR><TR><TD CLASS="l">273</TD><TD>                                }</TD></TR><TR CLASS="z"><TD CLASS="l">274</TD><TD>                        } catch (CoreException e) {</TD></TR><TR><TD CLASS="l">275</TD><TD>                        }</TD></TR><TR><TD CLASS="l"><A NAME="11">276</A></TD><TD>                }</TD></TR><TR CLASS="z"><TD CLASS="l">277</TD><TD>        }</TD></TR><TR><TD CLASS="l">278</TD><TD> </TD></TR><TR><TD CLASS="l">279</TD><TD>        public void breakpointRemoved(IBreakpoint breakpoint, IMarkerDelta delta) {</TD></TR><TR CLASS="z"><TD CLASS="l">280</TD><TD>                if (supportsBreakpoint(breakpoint)) {</TD></TR><TR><TD CLASS="l">281</TD><TD>                        try {</TD></TR><TR CLASS="z"><TD CLASS="l">282</TD><TD>                                ILineBreakpoint lb = (ILineBreakpoint) breakpoint;</TD></TR><TR CLASS="z"><TD CLASS="l">283</TD><TD>                                IMarker marker = lb.getMarker();</TD></TR><TR CLASS="z"><TD CLASS="l">284</TD><TD>                                if (marker != null) {</TD></TR><TR CLASS="z"><TD CLASS="l">285</TD><TD>                                        URL file = marker.getResource().getLocation().toFile()</TD></TR><TR CLASS="z"><TD CLASS="l">286</TD><TD>                                                        .toURI().toURL();</TD></TR><TR CLASS="z"><TD CLASS="l">287</TD><TD>                                        sendRequest(DebugConstants.REQUEST_REMOVE_BREAKPOINT</TD></TR><TR CLASS="z"><TD CLASS="l">288</TD><TD>                                                        + &#34; &#34; + file + &#34; &#34; + lb.getLineNumber()); //$NON-NLS-1$ //$NON-NLS-2$</TD></TR><TR><TD CLASS="l">289</TD><TD>                                }</TD></TR><TR CLASS="z"><TD CLASS="l">290</TD><TD>                        } catch (CoreException e) {</TD></TR><TR CLASS="z"><TD CLASS="l">291</TD><TD>                                JAXPLaunchingPlugin.log(e);</TD></TR><TR CLASS="z"><TD CLASS="l">292</TD><TD>                        } catch (MalformedURLException e) {</TD></TR><TR CLASS="z"><TD CLASS="l">293</TD><TD>                                JAXPLaunchingPlugin.log(e);</TD></TR><TR><TD CLASS="l">294</TD><TD>                        }</TD></TR><TR><TD CLASS="l"><A NAME="f">295</A></TD><TD>                }</TD></TR><TR CLASS="z"><TD CLASS="l">296</TD><TD>        }</TD></TR><TR><TD CLASS="l">297</TD><TD> </TD></TR><TR><TD CLASS="l">298</TD><TD>        public void breakpointChanged(IBreakpoint breakpoint, IMarkerDelta delta) {</TD></TR><TR CLASS="z"><TD CLASS="l">299</TD><TD>                if (supportsBreakpoint(breakpoint)) {</TD></TR><TR><TD CLASS="l">300</TD><TD>                        try {</TD></TR><TR CLASS="z"><TD CLASS="l">301</TD><TD>                                if (breakpoint.isEnabled()) {</TD></TR><TR CLASS="z"><TD CLASS="l">302</TD><TD>                                        breakpointAdded(breakpoint);</TD></TR><TR><TD CLASS="l">303</TD><TD>                                } else {</TD></TR><TR CLASS="z"><TD CLASS="l">304</TD><TD>                                        breakpointRemoved(breakpoint, null);</TD></TR><TR><TD CLASS="l">305</TD><TD>                                }</TD></TR><TR CLASS="z"><TD CLASS="l">306</TD><TD>                        } catch (CoreException e) {</TD></TR><TR><TD CLASS="l">307</TD><TD>                        }</TD></TR><TR><TD CLASS="l">308</TD><TD>                }</TD></TR><TR CLASS="z"><TD CLASS="l">309</TD><TD>        }</TD></TR><TR><TD CLASS="l"><A NAME="32">310</A></TD><TD> </TD></TR><TR><TD CLASS="l">311</TD><TD>        @Override</TD></TR><TR><TD CLASS="l">312</TD><TD>        public boolean canDisconnect() {</TD></TR><TR><TD CLASS="l">313</TD><TD>                // TODO implement disconnect</TD></TR><TR CLASS="c"><TD CLASS="l">314</TD><TD>                return false;</TD></TR><TR><TD CLASS="l">315</TD><TD>        }</TD></TR><TR><TD CLASS="l"><A NAME="14">316</A></TD><TD> </TD></TR><TR><TD CLASS="l">317</TD><TD>        @Override</TD></TR><TR><TD CLASS="l">318</TD><TD>        public void disconnect() throws DebugException {</TD></TR><TR><TD CLASS="l">319</TD><TD>                // TODO implement disconnect</TD></TR><TR CLASS="z"><TD CLASS="l">320</TD><TD>        }</TD></TR><TR><TD CLASS="l"><A NAME="20">321</A></TD><TD> </TD></TR><TR><TD CLASS="l">322</TD><TD>        @Override</TD></TR><TR><TD CLASS="l">323</TD><TD>        public boolean isDisconnected() {</TD></TR><TR><TD CLASS="l">324</TD><TD>                // TODO implement disconnect</TD></TR><TR CLASS="z"><TD CLASS="l"><A NAME="2b">325</A></TD><TD>                return false;</TD></TR><TR><TD CLASS="l">326</TD><TD>        }</TD></TR><TR><TD CLASS="l">327</TD><TD> </TD></TR><TR><TD CLASS="l">328</TD><TD>        public boolean supportsStorageRetrieval() {</TD></TR><TR CLASS="z"><TD CLASS="l">329</TD><TD>                return false;</TD></TR><TR><TD CLASS="l"><A NAME="18">330</A></TD><TD>        }</TD></TR><TR><TD CLASS="l">331</TD><TD> </TD></TR><TR><TD CLASS="l">332</TD><TD>        public IMemoryBlock getMemoryBlock(long startAddress, long length)</TD></TR><TR><TD CLASS="l"><A NAME="8">333</A></TD><TD>                        throws DebugException {</TD></TR><TR CLASS="z"><TD CLASS="l"><A NAME="22">334</A></TD><TD>                return null;</TD></TR><TR><TD CLASS="l">335</TD><TD>        }</TD></TR><TR><TD CLASS="l">336</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">337</TD><TD>        private void ready() {</TD></TR><TR CLASS="z"><TD CLASS="l">338</TD><TD>                fireCreationEvent();</TD></TR><TR CLASS="z"><TD CLASS="l">339</TD><TD>                installDeferredBreakpoints();</TD></TR><TR><TD CLASS="l">340</TD><TD>                try {</TD></TR><TR CLASS="z"><TD CLASS="l">341</TD><TD>                        sendRequest(DebugConstants.REQUEST_START);</TD></TR><TR CLASS="z"><TD CLASS="l">342</TD><TD>                } catch (DebugException e) {</TD></TR><TR CLASS="z"><TD CLASS="l">343</TD><TD>                        e.printStackTrace();</TD></TR><TR><TD CLASS="l">344</TD><TD>                }</TD></TR><TR CLASS="z"><TD CLASS="l">345</TD><TD>        }</TD></TR><TR><TD CLASS="l">346</TD><TD> </TD></TR><TR><TD CLASS="l">347</TD><TD>        /**</TD></TR><TR><TD CLASS="l"><A NAME="1f">348</A></TD><TD>         * Install breakpoints that are already registered with the breakpoint</TD></TR><TR><TD CLASS="l">349</TD><TD>         * manager.</TD></TR><TR><TD CLASS="l">350</TD><TD>         */</TD></TR><TR><TD CLASS="l">351</TD><TD>        private void installDeferredBreakpoints() {</TD></TR><TR CLASS="z"><TD CLASS="l">352</TD><TD>                IBreakpoint[] breakpoints = DebugPlugin.getDefault()</TD></TR><TR CLASS="z"><TD CLASS="l">353</TD><TD>                                .getBreakpointManager().getBreakpoints(</TD></TR><TR CLASS="z"><TD CLASS="l">354</TD><TD>                                                IXSLConstants.ID_XSL_DEBUG_MODEL);</TD></TR><TR CLASS="z"><TD CLASS="l">355</TD><TD>                for (IBreakpoint element : breakpoints) {</TD></TR><TR CLASS="z"><TD CLASS="l"><A NAME="9">356</A></TD><TD>                        breakpointAdded(element);</TD></TR><TR><TD CLASS="l"><A NAME="2f">357</A></TD><TD>                }</TD></TR><TR CLASS="z"><TD CLASS="l">358</TD><TD>        }</TD></TR><TR><TD CLASS="l">359</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">360</TD><TD>        private void terminated() {</TD></TR><TR CLASS="z"><TD CLASS="l">361</TD><TD>                suspended = true;</TD></TR><TR CLASS="z"><TD CLASS="l">362</TD><TD>                DebugPlugin.getDefault().getBreakpointManager().removeBreakpointListener(this);</TD></TR><TR CLASS="z"><TD CLASS="l">363</TD><TD>                threads = new IThread[0];</TD></TR><TR CLASS="z"><TD CLASS="l">364</TD><TD>                fireTerminateEvent();</TD></TR><TR CLASS="z"><TD CLASS="l">365</TD><TD>        }</TD></TR><TR><TD CLASS="l">366</TD><TD> </TD></TR><TR><TD CLASS="l"><A NAME="1a">367</A></TD><TD>        /**</TD></TR><TR><TD CLASS="l">368</TD><TD>         * Returns the current stack frames in the target.</TD></TR><TR><TD CLASS="l">369</TD><TD>         */</TD></TR><TR><TD CLASS="l">370</TD><TD>        public IStackFrame[] getStackFrames() throws DebugException {</TD></TR><TR CLASS="z"><TD CLASS="l">371</TD><TD>                synchronized (STACK_FRAMES_LOCK) {</TD></TR><TR CLASS="z"><TD CLASS="l">372</TD><TD>                        if (stale) {</TD></TR><TR CLASS="z"><TD CLASS="l">373</TD><TD>                                stale = false;</TD></TR><TR CLASS="z"><TD CLASS="l">374</TD><TD>                                String framesData = sendRequest(DebugConstants.REQUEST_STACK);</TD></TR><TR CLASS="z"><TD CLASS="l">375</TD><TD>                                String[] frames = framesData.split(&#34;\\$\\$\\$&#34;); //$NON-NLS-1$</TD></TR><TR CLASS="z"><TD CLASS="l">376</TD><TD>                                IStackFrame[] sf = new IStackFrame[frames.length];</TD></TR><TR CLASS="z"><TD CLASS="l">377</TD><TD>                                List&lt;IStackFrame&gt; currentFrames = Arrays</TD></TR><TR CLASS="z"><TD CLASS="l">378</TD><TD>                                                .asList(stackFramesCache);</TD></TR><TR CLASS="z"><TD CLASS="l">379</TD><TD>                                for (int i = 0; i &lt; frames.length; i++) {</TD></TR><TR CLASS="z"><TD CLASS="l">380</TD><TD>                                        String data = frames[i];</TD></TR><TR CLASS="z"><TD CLASS="l">381</TD><TD>                                        XSLStackFrame frame = new XSLStackFrame(thread, data, i);</TD></TR><TR><TD CLASS="l">382</TD><TD>                                        int index;</TD></TR><TR CLASS="z"><TD CLASS="l">383</TD><TD>                                        if ((index = currentFrames.indexOf(frame)) != -1) {</TD></TR><TR CLASS="z"><TD CLASS="l">384</TD><TD>                                                XSLStackFrame curr = (XSLStackFrame) currentFrames</TD></TR><TR CLASS="z"><TD CLASS="l">385</TD><TD>                                                                .get(index);</TD></TR><TR CLASS="z"><TD CLASS="l">386</TD><TD>                                                curr.setLineNumber(frame.getLineNumber());</TD></TR><TR CLASS="z"><TD CLASS="l">387</TD><TD>                                                curr.setVariables(frame.getVariables());</TD></TR><TR CLASS="z"><TD CLASS="l">388</TD><TD>                                                frame = curr;</TD></TR><TR><TD CLASS="l">389</TD><TD>                                        }</TD></TR><TR CLASS="z"><TD CLASS="l">390</TD><TD>                                        sf[frames.length - i - 1] = frame;</TD></TR><TR><TD CLASS="l">391</TD><TD>                                }</TD></TR><TR CLASS="z"><TD CLASS="l">392</TD><TD>                                stackFramesCache = sf;</TD></TR><TR><TD CLASS="l">393</TD><TD>                        }</TD></TR><TR CLASS="z"><TD CLASS="l"><A NAME="b">394</A></TD><TD>                        return stackFramesCache;</TD></TR><TR><TD CLASS="l"><A NAME="23">395</A></TD><TD>                }</TD></TR><TR><TD CLASS="l">396</TD><TD>        }</TD></TR><TR><TD CLASS="l">397</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">398</TD><TD>        private void ressetStackFramesCache() {</TD></TR><TR CLASS="z"><TD CLASS="l">399</TD><TD>                stale = true;</TD></TR><TR CLASS="z"><TD CLASS="l">400</TD><TD>                synchronized (VALUE_MAP_LOCK) {</TD></TR><TR CLASS="z"><TD CLASS="l">401</TD><TD>                        valueMapCache.clear();</TD></TR><TR><TD CLASS="l">402</TD><TD>                }</TD></TR><TR CLASS="z"><TD CLASS="l">403</TD><TD>        }</TD></TR><TR><TD CLASS="l">404</TD><TD> </TD></TR><TR><TD CLASS="l"><A NAME="28">405</A></TD><TD>        /**</TD></TR><TR><TD CLASS="l">406</TD><TD>         * Single step the interpreter.</TD></TR><TR><TD CLASS="l">407</TD><TD>         */</TD></TR><TR><TD CLASS="l">408</TD><TD>        public void stepOver() throws DebugException {</TD></TR><TR CLASS="z"><TD CLASS="l"><A NAME="27">409</A></TD><TD>                sendRequest(DebugConstants.REQUEST_STEP_OVER);</TD></TR><TR CLASS="z"><TD CLASS="l">410</TD><TD>        }</TD></TR><TR><TD CLASS="l">411</TD><TD> </TD></TR><TR><TD CLASS="l">412</TD><TD>        public void stepInto() throws DebugException {</TD></TR><TR CLASS="z"><TD CLASS="l"><A NAME="29">413</A></TD><TD>                sendRequest(DebugConstants.REQUEST_STEP_INTO);</TD></TR><TR CLASS="z"><TD CLASS="l">414</TD><TD>        }</TD></TR><TR><TD CLASS="l">415</TD><TD> </TD></TR><TR><TD CLASS="l">416</TD><TD>        public void stepReturn() throws DebugException {</TD></TR><TR CLASS="z"><TD CLASS="l"><A NAME="1c">417</A></TD><TD>                sendRequest(DebugConstants.REQUEST_STEP_RETURN);</TD></TR><TR CLASS="z"><TD CLASS="l">418</TD><TD>        }</TD></TR><TR><TD CLASS="l">419</TD><TD> </TD></TR><TR><TD CLASS="l">420</TD><TD>        public XSLVariable getVariable(int varId) throws DebugException {</TD></TR><TR CLASS="z"><TD CLASS="l">421</TD><TD>                synchronized (variableMapCache) {</TD></TR><TR CLASS="z"><TD CLASS="l">422</TD><TD>                        XSLVariable var = variableMapCache.get(varId);</TD></TR><TR CLASS="z"><TD CLASS="l">423</TD><TD>                        if (var == null) {</TD></TR><TR CLASS="z"><TD CLASS="l">424</TD><TD>                                var = new XSLVariable(this, varId);</TD></TR><TR CLASS="z"><TD CLASS="l">425</TD><TD>                                String res = sendRequest(DebugConstants.REQUEST_VARIABLE</TD></TR><TR CLASS="z"><TD CLASS="l">426</TD><TD>                                                + &#34; &#34; + varId); //$NON-NLS-1$</TD></TR><TR CLASS="z"><TD CLASS="l">427</TD><TD>                                String[] data = res.split(&#34;&amp;&#34;); //$NON-NLS-1$</TD></TR><TR CLASS="z"><TD CLASS="l">428</TD><TD>                                var.setScope(data[0]);</TD></TR><TR CLASS="z"><TD CLASS="l">429</TD><TD>                                var.setName(data[1]);</TD></TR><TR CLASS="z"><TD CLASS="l">430</TD><TD>                                variableMapCache.put(varId, var);</TD></TR><TR><TD CLASS="l">431</TD><TD>                        }</TD></TR><TR CLASS="z"><TD CLASS="l">432</TD><TD>                        return var;</TD></TR><TR><TD CLASS="l"><A NAME="1d">433</A></TD><TD>                }</TD></TR><TR><TD CLASS="l">434</TD><TD>        }</TD></TR><TR><TD CLASS="l">435</TD><TD> </TD></TR><TR><TD CLASS="l">436</TD><TD>        public IValue getVariableValue(XSLVariable variable) throws DebugException {</TD></TR><TR CLASS="z"><TD CLASS="l">437</TD><TD>                synchronized (VALUE_MAP_LOCK) {</TD></TR><TR CLASS="z"><TD CLASS="l">438</TD><TD>                        XSLValue value = valueMapCache.get(variable);</TD></TR><TR CLASS="z"><TD CLASS="l">439</TD><TD>                        if (value == null) {</TD></TR><TR CLASS="z"><TD CLASS="l">440</TD><TD>                                if (isSuspended()) {</TD></TR><TR CLASS="z"><TD CLASS="l">441</TD><TD>                                        String res = sendRequest(DebugConstants.REQUEST_VALUE</TD></TR><TR CLASS="z"><TD CLASS="l">442</TD><TD>                                                        + &#34; &#34; + variable.getId()); //$NON-NLS-1$</TD></TR><TR CLASS="z"><TD CLASS="l">443</TD><TD>                                        String[] data = res.split(&#34;&amp;&#34;); //$NON-NLS-1$</TD></TR><TR CLASS="z"><TD CLASS="l">444</TD><TD>                                        String type = data[0];</TD></TR><TR><TD CLASS="l">445</TD><TD>                                        String theval;</TD></TR><TR CLASS="z"><TD CLASS="l">446</TD><TD>                                        if (data.length &gt; 1)</TD></TR><TR CLASS="z"><TD CLASS="l">447</TD><TD>                                                theval = data[1];</TD></TR><TR><TD CLASS="l">448</TD><TD>                                        else</TD></TR><TR CLASS="z"><TD CLASS="l">449</TD><TD>                                                theval = &#34;&#34;; //$NON-NLS-1$</TD></TR><TR CLASS="z"><TD CLASS="l">450</TD><TD>                                        value = new XSLValue(this, type, theval);</TD></TR><TR CLASS="z"><TD CLASS="l">451</TD><TD>                                        valueMapCache.put(variable, value);</TD></TR><TR><TD CLASS="l">452</TD><TD>                                } else {</TD></TR><TR><TD CLASS="l">453</TD><TD>                                        // anything as long as not null!</TD></TR><TR CLASS="z"><TD CLASS="l">454</TD><TD>                                        value = new XSLValue(this, &#34;G&#34;, &#34;&#34;); //$NON-NLS-1$ //$NON-NLS-2$</TD></TR><TR><TD CLASS="l">455</TD><TD>                                }</TD></TR><TR><TD CLASS="l">456</TD><TD>                        }</TD></TR><TR CLASS="z"><TD CLASS="l">457</TD><TD>                        return value;</TD></TR><TR><TD CLASS="l"><A NAME="26">458</A></TD><TD>                }</TD></TR><TR><TD CLASS="l">459</TD><TD>        }</TD></TR><TR><TD CLASS="l">460</TD><TD> </TD></TR><TR><TD CLASS="l">461</TD><TD>        private String sendRequest(String request) throws DebugException {</TD></TR><TR CLASS="z"><TD CLASS="l">462</TD><TD>                String response = null;</TD></TR><TR CLASS="z"><TD CLASS="l">463</TD><TD>                synchronized (WRITE_LOCK) {</TD></TR><TR><TD CLASS="l">464</TD><TD>//                        if (Debug.debugLauncher) {</TD></TR><TR><TD CLASS="l">465</TD><TD>//                                System.out.println(&#34;REQUEST: &#34; + request);</TD></TR><TR><TD CLASS="l">466</TD><TD>//                        }</TD></TR><TR CLASS="z"><TD CLASS="l">467</TD><TD>                        requestWriter.println(request);</TD></TR><TR CLASS="z"><TD CLASS="l">468</TD><TD>                        requestWriter.flush();</TD></TR><TR><TD CLASS="l">469</TD><TD>                        try {</TD></TR><TR><TD CLASS="l">470</TD><TD>                                // wait for response</TD></TR><TR CLASS="z"><TD CLASS="l">471</TD><TD>                                response = requestReader.readLine();</TD></TR><TR><TD CLASS="l">472</TD><TD>//                                if (Debug.debugLauncher) {</TD></TR><TR><TD CLASS="l">473</TD><TD>//                                        System.out.println(&#34;RESPONSE: &#34; + response);</TD></TR><TR><TD CLASS="l">474</TD><TD>//                                }</TD></TR><TR CLASS="z"><TD CLASS="l">475</TD><TD>                        } catch (IOException e) {</TD></TR><TR CLASS="z"><TD CLASS="l">476</TD><TD>                                abort(Messages.XSLDebugTarget_19 + request, e); </TD></TR><TR><TD CLASS="l">477</TD><TD>                        }</TD></TR><TR><TD CLASS="l"><A NAME="d">478</A></TD><TD>                }</TD></TR><TR CLASS="z"><TD CLASS="l">479</TD><TD>                return response;</TD></TR><TR><TD CLASS="l"><A NAME="10">480</A></TD><TD>        }</TD></TR><TR><TD CLASS="l">481</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">482</TD><TD>        private void breakpointHit(String event) {</TD></TR><TR><TD CLASS="l">483</TD><TD>                // determine which breakpoint was hit, and set the thread's breakpoint</TD></TR><TR CLASS="z"><TD CLASS="l">484</TD><TD>                int lastSpace = event.lastIndexOf(' ');</TD></TR><TR CLASS="z"><TD CLASS="l">485</TD><TD>                if (lastSpace &gt; 0) {</TD></TR><TR CLASS="z"><TD CLASS="l">486</TD><TD>                        String line = event.substring(lastSpace + 1);</TD></TR><TR CLASS="z"><TD CLASS="l">487</TD><TD>                        int lineNumber = Integer.parseInt(line);</TD></TR><TR CLASS="z"><TD CLASS="l">488</TD><TD>                        IBreakpoint[] breakpoints = DebugPlugin.getDefault()</TD></TR><TR CLASS="z"><TD CLASS="l">489</TD><TD>                                        .getBreakpointManager().getBreakpoints(</TD></TR><TR CLASS="z"><TD CLASS="l">490</TD><TD>                                                        IXSLConstants.ID_XSL_DEBUG_MODEL);</TD></TR><TR CLASS="z"><TD CLASS="l">491</TD><TD>                        for (IBreakpoint breakpoint : breakpoints) {</TD></TR><TR CLASS="z"><TD CLASS="l">492</TD><TD>                                if (supportsBreakpoint(breakpoint)) {</TD></TR><TR CLASS="z"><TD CLASS="l">493</TD><TD>                                        if (breakpoint instanceof ILineBreakpoint) {</TD></TR><TR CLASS="z"><TD CLASS="l">494</TD><TD>                                                ILineBreakpoint lineBreakpoint = (ILineBreakpoint) breakpoint;</TD></TR><TR><TD CLASS="l">495</TD><TD>                                                try {</TD></TR><TR CLASS="z"><TD CLASS="l">496</TD><TD>                                                        if (lineBreakpoint.getLineNumber() == lineNumber) {</TD></TR><TR CLASS="z"><TD CLASS="l">497</TD><TD>                                                                thread</TD></TR><TR CLASS="z"><TD CLASS="l">498</TD><TD>                                                                                .setBreakpoints(new IBreakpoint[] { breakpoint });</TD></TR><TR CLASS="z"><TD CLASS="l">499</TD><TD>                                                                break;</TD></TR><TR><TD CLASS="l">500</TD><TD>                                                        }</TD></TR><TR CLASS="z"><TD CLASS="l">501</TD><TD>                                                } catch (CoreException e) {</TD></TR><TR><TD CLASS="l">502</TD><TD>                                                }</TD></TR><TR><TD CLASS="l">503</TD><TD>                                        }</TD></TR><TR><TD CLASS="l">504</TD><TD>                                }</TD></TR><TR><TD CLASS="l">505</TD><TD>                        }</TD></TR><TR><TD CLASS="l">506</TD><TD>                }</TD></TR><TR CLASS="z"><TD CLASS="l">507</TD><TD>                suspended(DebugEvent.BREAKPOINT);</TD></TR><TR CLASS="z"><TD CLASS="l">508</TD><TD>        }</TD></TR><TR><TD CLASS="l">509</TD><TD> </TD></TR><TR><TD CLASS="l">510</TD><TD>        private class EventDispatchJob extends Job {</TD></TR><TR><TD CLASS="l"><A NAME="0">511</A></TD><TD> </TD></TR><TR><TD CLASS="l">512</TD><TD>                public EventDispatchJob() {</TD></TR><TR CLASS="z"><TD CLASS="l">513</TD><TD>                        super(Messages.XSLDebugTarget_20); </TD></TR><TR CLASS="z"><TD CLASS="l">514</TD><TD>                        setSystem(true);</TD></TR><TR CLASS="z"><TD CLASS="l"><A NAME="3">515</A></TD><TD>                }</TD></TR><TR><TD CLASS="l">516</TD><TD> </TD></TR><TR><TD CLASS="l">517</TD><TD>                @Override</TD></TR><TR><TD CLASS="l">518</TD><TD>                protected IStatus run(IProgressMonitor monitor) {</TD></TR><TR CLASS="z"><TD CLASS="l">519</TD><TD>                        String event = &#34;&#34;; //$NON-NLS-1$</TD></TR><TR CLASS="z"><TD CLASS="l">520</TD><TD>                        while (!isTerminated() &amp;&amp; event != null) {</TD></TR><TR><TD CLASS="l">521</TD><TD>                                try {</TD></TR><TR CLASS="z"><TD CLASS="l">522</TD><TD>                                        event = eventReader.readLine();</TD></TR><TR CLASS="z"><TD CLASS="l">523</TD><TD>                                        if (event != null) {</TD></TR><TR CLASS="z"><TD CLASS="l">524</TD><TD>                                                thread.setBreakpoints(null);</TD></TR><TR CLASS="z"><TD CLASS="l">525</TD><TD>                                                thread.setStepping(false);</TD></TR><TR CLASS="z"><TD CLASS="l">526</TD><TD>                                                if (event.equals(&#34;ready&#34;)) //$NON-NLS-1$</TD></TR><TR CLASS="z"><TD CLASS="l">527</TD><TD>                                                {</TD></TR><TR CLASS="z"><TD CLASS="l">528</TD><TD>                                                        ready();</TD></TR><TR CLASS="z"><TD CLASS="l">529</TD><TD>                                                } else if (event.equals(&#34;stopped&#34;)) //$NON-NLS-1$</TD></TR><TR><TD CLASS="l">530</TD><TD>                                                {</TD></TR><TR CLASS="z"><TD CLASS="l">531</TD><TD>                                                        try {</TD></TR><TR CLASS="z"><TD CLASS="l">532</TD><TD>                                                                terminate();</TD></TR><TR CLASS="z"><TD CLASS="l">533</TD><TD>                                                        } catch (DebugException e) {</TD></TR><TR><TD CLASS="l">534</TD><TD>                                                        }</TD></TR><TR CLASS="z"><TD CLASS="l">535</TD><TD>                                                } else if (event.equals(&#34;terminated&#34;)) //$NON-NLS-1$</TD></TR><TR CLASS="z"><TD CLASS="l">536</TD><TD>                                                {</TD></TR><TR CLASS="z"><TD CLASS="l">537</TD><TD>                                                        terminated();</TD></TR><TR CLASS="z"><TD CLASS="l">538</TD><TD>                                                } else if (event.startsWith(&#34;resumed&#34;)) //$NON-NLS-1$</TD></TR><TR><TD CLASS="l">539</TD><TD>                                                {</TD></TR><TR CLASS="z"><TD CLASS="l">540</TD><TD>                                                        if (event.endsWith(&#34;step&#34;)) //$NON-NLS-1$</TD></TR><TR><TD CLASS="l">541</TD><TD>                                                        {</TD></TR><TR CLASS="z"><TD CLASS="l">542</TD><TD>                                                                thread.setStepping(true);</TD></TR><TR CLASS="z"><TD CLASS="l">543</TD><TD>                                                                resumed(DebugEvent.STEP_OVER);</TD></TR><TR CLASS="z"><TD CLASS="l">544</TD><TD>                                                        } else if (event.endsWith(&#34;client&#34;)) //$NON-NLS-1$</TD></TR><TR CLASS="z"><TD CLASS="l">545</TD><TD>                                                        {</TD></TR><TR CLASS="z"><TD CLASS="l">546</TD><TD>                                                                resumed(DebugEvent.CLIENT_REQUEST);</TD></TR><TR><TD CLASS="l">547</TD><TD>                                                        } else {</TD></TR><TR CLASS="z"><TD CLASS="l">548</TD><TD>                                                                debugEventMsg(event);</TD></TR><TR><TD CLASS="l">549</TD><TD>                                                        }</TD></TR><TR CLASS="z"><TD CLASS="l">550</TD><TD>                                                } else if (event.startsWith(&#34;suspended&#34;)) //$NON-NLS-1$</TD></TR><TR CLASS="z"><TD CLASS="l">551</TD><TD>                                                {</TD></TR><TR><TD CLASS="l">552</TD><TD>                                                        // clear down the frames so that they are re-fetched</TD></TR><TR CLASS="z"><TD CLASS="l">553</TD><TD>                                                        ressetStackFramesCache();</TD></TR><TR CLASS="z"><TD CLASS="l">554</TD><TD>                                                        if (event.endsWith(&#34;client&#34;)) //$NON-NLS-1$</TD></TR><TR CLASS="z"><TD CLASS="l">555</TD><TD>                                                        {</TD></TR><TR CLASS="z"><TD CLASS="l">556</TD><TD>                                                                suspended(DebugEvent.CLIENT_REQUEST);</TD></TR><TR CLASS="z"><TD CLASS="l">557</TD><TD>                                                        } else if (event.endsWith(&#34;step&#34;)) //$NON-NLS-1$</TD></TR><TR CLASS="z"><TD CLASS="l">558</TD><TD>                                                        {</TD></TR><TR CLASS="z"><TD CLASS="l">559</TD><TD>                                                                suspended(DebugEvent.STEP_END);</TD></TR><TR CLASS="z"><TD CLASS="l">560</TD><TD>                                                        } else if (event.indexOf(&#34;breakpoint&#34;) &gt;= 0) //$NON-NLS-1$</TD></TR><TR CLASS="z"><TD CLASS="l">561</TD><TD>                                                        {</TD></TR><TR CLASS="z"><TD CLASS="l">562</TD><TD>                                                                breakpointHit(event);</TD></TR><TR><TD CLASS="l">563</TD><TD>                                                        } else {</TD></TR><TR CLASS="z"><TD CLASS="l">564</TD><TD>                                                                debugEventMsg(event);</TD></TR><TR><TD CLASS="l">565</TD><TD>                                                        }</TD></TR><TR><TD CLASS="l">566</TD><TD>                                                } else {</TD></TR><TR CLASS="z"><TD CLASS="l">567</TD><TD>                                                        debugEventMsg(event);</TD></TR><TR><TD CLASS="l">568</TD><TD>                                                }</TD></TR><TR><TD CLASS="l">569</TD><TD>                                        }</TD></TR><TR CLASS="z"><TD CLASS="l">570</TD><TD>                                } catch (IOException e) {</TD></TR><TR CLASS="z"><TD CLASS="l">571</TD><TD>                                        terminated();</TD></TR><TR><TD CLASS="l">572</TD><TD>                                }</TD></TR><TR><TD CLASS="l">573</TD><TD>                        }</TD></TR><TR CLASS="z"><TD CLASS="l">574</TD><TD>                        return Status.OK_STATUS;</TD></TR><TR><TD CLASS="l">575</TD><TD>                }</TD></TR><TR><TD CLASS="l">576</TD><TD> </TD></TR><TR><TD CLASS="l"><A NAME="2">577</A></TD><TD>                private void debugEventMsg(String event) {</TD></TR><TR><TD CLASS="l">578</TD><TD>//                        if (Debug.debugLauncher) {</TD></TR><TR><TD CLASS="l">579</TD><TD>//                                 System.out.println(&#34;Did not understand event:&#34; + event);</TD></TR><TR><TD CLASS="l">580</TD><TD>//                        }</TD></TR><TR CLASS="z"><TD CLASS="l">581</TD><TD>                }</TD></TR><TR><TD CLASS="l">582</TD><TD>        }</TD></TR><TR><TD CLASS="l">583</TD><TD>}</TD></TR></TABLE><P></P><TABLE CLASS="hdft" CELLSPACING="0" WIDTH="100%"><TR><TD CLASS="nv">[<A HREF="../xslUnitTestCoverage.html">all classes</A>][<A HREF="7c.html">org.eclipse.wst.xsl.jaxp.launching.model</A>]</TD></TR><TR><TD CLASS="tl"><A HREF="http://www.eclemma.org/support.html">EMMA 2.0.5312 EclEmma Fix 1</A> (C) Vladimir Roubtsov</TD></TR></TABLE></BODY></HTML>