blob: 41c546831b7e9ffeef317ea8ebab059e7cc9a86d [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="ae.html">org.eclipse.wst.sse.core.internal.provisional</A>]</TD></TR></TABLE><H2>COVERAGE SUMMARY FOR SOURCE FILE [<SPAN CLASS="in">AbstractNotifier.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>AbstractNotifier.java</TD><TD>100% (1/1)</TD><TD CLASS="h">60%  (6/10)</TD><TD CLASS="h">44%  (144/326)</TD><TD CLASS="h">48%  (39.9/83)</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">AbstractNotifier</A></TD><TD>100% (1/1)</TD><TD CLASS="h">60%  (6/10)</TD><TD CLASS="h">44%  (144/326)</TD><TD CLASS="h">48%  (39.9/83)</TD></TR><TR><TD CLASS="f"><A HREF="#1">getAdapterCount (): int</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="#2">getAdapterTimeCriteria (): long</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/14)</TD><TD CLASS="h">0%   (0/6)</TD></TR><TR><TD CLASS="f"><A HREF="#3">getAdapters (): Collection</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/29)</TD><TD CLASS="h">0%   (0/8)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#4">removeAdapter (INodeAdapter): void</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/56)</TD><TD CLASS="h">0%   (0/15)</TD></TR><TR><TD CLASS="f"><A HREF="#5">notify (int, Object, Object, Object, int): void</A></TD><TD> </TD><TD>100% (1/1)</TD><TD CLASS="h">46%  (51/112)</TD><TD CLASS="h">59%  (11.9/20)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#6">ensureCapacity (int): void</A></TD><TD> </TD><TD>100% (1/1)</TD><TD CLASS="h">50%  (18/36)</TD><TD CLASS="h">60%  (6/10)</TD></TR><TR><TD CLASS="f"><A HREF="#7">addAdapter (INodeAdapter): void</A></TD><TD> </TD><TD>100% (1/1)</TD><TD>95%  (20/21)</TD><TD>80%  (4/5)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#0">AbstractNotifier (): void</A></TD><TD> </TD><TD>100% (1/1)</TD><TD>100% (6/6)</TD><TD>100% (3/3)</TD></TR><TR><TD CLASS="f"><A HREF="#9">getAdapterFor (Object): INodeAdapter</A></TD><TD> </TD><TD>100% (1/1)</TD><TD>100% (23/23)</TD><TD>100% (8/8)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#a">getExistingAdapter (Object): INodeAdapter</A></TD><TD> </TD><TD>100% (1/1)</TD><TD>100% (26/26)</TD><TD>100% (7/7)</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) 2001, 2005 IBM Corporation and others.</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> *     IBM Corporation - initial API and implementation</TD></TR><TR><TD CLASS="l">10</TD><TD> *     Jens Lukowski/Innoopract - initial renaming/restructuring</TD></TR><TR><TD CLASS="l">11</TD><TD> *     </TD></TR><TR><TD CLASS="l">12</TD><TD> *******************************************************************************/</TD></TR><TR><TD CLASS="l">13</TD><TD>package org.eclipse.wst.sse.core.internal.provisional;</TD></TR><TR><TD CLASS="l">14</TD><TD> </TD></TR><TR><TD CLASS="l">15</TD><TD>import java.util.Arrays;</TD></TR><TR><TD CLASS="l">16</TD><TD>import java.util.Collection;</TD></TR><TR><TD CLASS="l">17</TD><TD>import java.util.Collections;</TD></TR><TR><TD CLASS="l">18</TD><TD> </TD></TR><TR><TD CLASS="l">19</TD><TD>import org.eclipse.core.runtime.Platform;</TD></TR><TR><TD CLASS="l">20</TD><TD>import org.eclipse.wst.sse.core.internal.Logger;</TD></TR><TR><TD CLASS="l">21</TD><TD>import org.eclipse.wst.sse.core.internal.model.FactoryRegistry;</TD></TR><TR><TD CLASS="l">22</TD><TD> </TD></TR><TR><TD CLASS="l">23</TD><TD> </TD></TR><TR><TD CLASS="l">24</TD><TD> </TD></TR><TR><TD CLASS="l">25</TD><TD>/**</TD></TR><TR><TD CLASS="l">26</TD><TD> * AbstractNotifier is similar to (and based on) the EMF NotifierImpl class,</TD></TR><TR><TD CLASS="l">27</TD><TD> * but is not related to EMF per se. This class is simpler (that is, not as</TD></TR><TR><TD CLASS="l">28</TD><TD> * many functions).</TD></TR><TR><TD CLASS="l">29</TD><TD> * </TD></TR><TR><TD CLASS="l">30</TD><TD> * Implementers of this INodeNotifier must subclass this class.</TD></TR><TR><TD CLASS="l">31</TD><TD> */</TD></TR><TR><TD CLASS="l">32</TD><TD>public abstract class AbstractNotifier implements INodeNotifier {</TD></TR><TR><TD CLASS="l">33</TD><TD>        private final static int growthConstant = 3;</TD></TR><TR CLASS="c"><TD CLASS="l">34</TD><TD>        private int adapterCount = 0;</TD></TR><TR><TD CLASS="l">35</TD><TD> </TD></TR><TR><TD CLASS="l">36</TD><TD>        private INodeAdapter[] fAdapters;</TD></TR><TR><TD CLASS="l">37</TD><TD> </TD></TR><TR><TD CLASS="l"><A NAME="0">38</A></TD><TD>        /**</TD></TR><TR><TD CLASS="l">39</TD><TD>         * AbstractNotifier constructor comment.</TD></TR><TR><TD CLASS="l">40</TD><TD>         */</TD></TR><TR><TD CLASS="l">41</TD><TD>        public AbstractNotifier() {</TD></TR><TR CLASS="c"><TD CLASS="l">42</TD><TD>                super();</TD></TR><TR CLASS="c"><TD CLASS="l">43</TD><TD>        }</TD></TR><TR><TD CLASS="l">44</TD><TD> </TD></TR><TR><TD CLASS="l">45</TD><TD>        /**</TD></TR><TR><TD CLASS="l"><A NAME="7">46</A></TD><TD>         * addAdapter method comment.</TD></TR><TR><TD CLASS="l">47</TD><TD>         */</TD></TR><TR><TD CLASS="l">48</TD><TD>        public synchronized void addAdapter(INodeAdapter adapter) {</TD></TR><TR><TD CLASS="l">49</TD><TD> </TD></TR><TR CLASS="c"><TD CLASS="l">50</TD><TD>                if (adapter == null)</TD></TR><TR CLASS="z"><TD CLASS="l">51</TD><TD>                        return;</TD></TR><TR CLASS="c"><TD CLASS="l">52</TD><TD>                ensureCapacity(adapterCount + 1);</TD></TR><TR CLASS="c"><TD CLASS="l"><A NAME="6">53</A></TD><TD>                fAdapters[adapterCount++] = adapter;</TD></TR><TR CLASS="c"><TD CLASS="l">54</TD><TD>        }</TD></TR><TR><TD CLASS="l">55</TD><TD> </TD></TR><TR><TD CLASS="l">56</TD><TD>        private void ensureCapacity(int needed) {</TD></TR><TR CLASS="c"><TD CLASS="l">57</TD><TD>                if (fAdapters == null) {</TD></TR><TR><TD CLASS="l">58</TD><TD>                        // first time</TD></TR><TR CLASS="c"><TD CLASS="l">59</TD><TD>                        fAdapters = new INodeAdapter[needed + growthConstant];</TD></TR><TR CLASS="c"><TD CLASS="l">60</TD><TD>                        return;</TD></TR><TR><TD CLASS="l">61</TD><TD>                }</TD></TR><TR CLASS="c"><TD CLASS="l">62</TD><TD>                int oldLength = fAdapters.length;</TD></TR><TR CLASS="c"><TD CLASS="l">63</TD><TD>                if (oldLength &lt; needed) {</TD></TR><TR CLASS="z"><TD CLASS="l">64</TD><TD>                        INodeAdapter[] oldAdapters = fAdapters;</TD></TR><TR CLASS="z"><TD CLASS="l">65</TD><TD>                        INodeAdapter[] newAdapters = new INodeAdapter[needed + growthConstant];</TD></TR><TR CLASS="z"><TD CLASS="l">66</TD><TD>                        System.arraycopy(oldAdapters, 0, newAdapters, 0, adapterCount);</TD></TR><TR CLASS="z"><TD CLASS="l">67</TD><TD>                        fAdapters = newAdapters;</TD></TR><TR><TD CLASS="l">68</TD><TD>                }</TD></TR><TR CLASS="c"><TD CLASS="l">69</TD><TD>        }</TD></TR><TR><TD CLASS="l">70</TD><TD> </TD></TR><TR><TD CLASS="l">71</TD><TD>        /**</TD></TR><TR><TD CLASS="l">72</TD><TD>         * NOT API: used only for testing.</TD></TR><TR><TD CLASS="l"><A NAME="1">73</A></TD><TD>         * </TD></TR><TR><TD CLASS="l">74</TD><TD>         * @return int</TD></TR><TR><TD CLASS="l">75</TD><TD>         */</TD></TR><TR><TD CLASS="l">76</TD><TD>        public int getAdapterCount() {</TD></TR><TR CLASS="z"><TD CLASS="l">77</TD><TD>                return adapterCount;</TD></TR><TR><TD CLASS="l">78</TD><TD>        }</TD></TR><TR><TD CLASS="l">79</TD><TD> </TD></TR><TR><TD CLASS="l">80</TD><TD>        /**</TD></TR><TR><TD CLASS="l"><A NAME="9">81</A></TD><TD>         * Default behavior for getting an adapter.</TD></TR><TR><TD CLASS="l">82</TD><TD>         */</TD></TR><TR><TD CLASS="l">83</TD><TD>        public INodeAdapter getAdapterFor(Object type) {</TD></TR><TR><TD CLASS="l">84</TD><TD>                // first, we'll see if we already have one</TD></TR><TR CLASS="c"><TD CLASS="l">85</TD><TD>                INodeAdapter result = getExistingAdapter(type);</TD></TR><TR><TD CLASS="l">86</TD><TD>                // if we didn't find one in our list already,</TD></TR><TR><TD CLASS="l">87</TD><TD>                // let's create it</TD></TR><TR CLASS="c"><TD CLASS="l">88</TD><TD>                if (result == null) {</TD></TR><TR CLASS="c"><TD CLASS="l">89</TD><TD>                        FactoryRegistry reg = getFactoryRegistry();</TD></TR><TR CLASS="c"><TD CLASS="l">90</TD><TD>                        if (reg != null) {</TD></TR><TR CLASS="c"><TD CLASS="l">91</TD><TD>                                INodeAdapterFactory factory = reg.getFactoryFor(type);</TD></TR><TR CLASS="c"><TD CLASS="l">92</TD><TD>                                if (factory != null) {</TD></TR><TR CLASS="c"><TD CLASS="l">93</TD><TD>                                        result = factory.adapt(this);</TD></TR><TR><TD CLASS="l">94</TD><TD>                                }</TD></TR><TR><TD CLASS="l">95</TD><TD>                        }</TD></TR><TR><TD CLASS="l">96</TD><TD>                        // We won't prevent null from being returned, but it would be</TD></TR><TR><TD CLASS="l">97</TD><TD>                        // unusual.</TD></TR><TR><TD CLASS="l">98</TD><TD>                        // It might be because Factory is not working correctly, or</TD></TR><TR><TD CLASS="l">99</TD><TD>                        // not installed, so we'll allow warning message.</TD></TR><TR><TD CLASS="l">100</TD><TD>                        if ((result == null) &amp;&amp; (org.eclipse.wst.sse.core.internal.util.Debug.displayWarnings)) {</TD></TR><TR><TD CLASS="l">101</TD><TD>                                System.out.println(&#34;Warning: no adapter was found or created for &#34; + type); //$NON-NLS-1$</TD></TR><TR><TD CLASS="l">102</TD><TD>                        }</TD></TR><TR><TD CLASS="l">103</TD><TD>                }</TD></TR><TR CLASS="c"><TD CLASS="l">104</TD><TD>                return result;</TD></TR><TR><TD CLASS="l">105</TD><TD>        }</TD></TR><TR><TD CLASS="l">106</TD><TD> </TD></TR><TR><TD CLASS="l">107</TD><TD>        /**</TD></TR><TR><TD CLASS="l"><A NAME="3">108</A></TD><TD>         * Returns a shallow clone of list, since clients should not manipulate</TD></TR><TR><TD CLASS="l">109</TD><TD>         * our list directly. Instead, they should use add/removeAdapter.</TD></TR><TR><TD CLASS="l">110</TD><TD>         */</TD></TR><TR><TD CLASS="l">111</TD><TD>        public Collection getAdapters() {</TD></TR><TR CLASS="z"><TD CLASS="l">112</TD><TD>                if (fAdapters != null) {</TD></TR><TR CLASS="z"><TD CLASS="l">113</TD><TD>                        if (adapterCount == 0) {</TD></TR><TR CLASS="z"><TD CLASS="l">114</TD><TD>                                fAdapters = null;</TD></TR><TR CLASS="z"><TD CLASS="l">115</TD><TD>                                return Collections.EMPTY_LIST;</TD></TR><TR><TD CLASS="l">116</TD><TD>                        }</TD></TR><TR><TD CLASS="l">117</TD><TD>                        else {</TD></TR><TR><TD CLASS="l">118</TD><TD>                                // we need to make a new array, to be sure</TD></TR><TR><TD CLASS="l">119</TD><TD>                                // it doesn't contain nulls at end, which may be</TD></TR><TR><TD CLASS="l">120</TD><TD>                                // present there for &#34;growth&#34;.</TD></TR><TR CLASS="z"><TD CLASS="l">121</TD><TD>                                INodeAdapter[] tempAdapters = new INodeAdapter[adapterCount];</TD></TR><TR CLASS="z"><TD CLASS="l">122</TD><TD>                                System.arraycopy(fAdapters, 0, tempAdapters, 0, adapterCount);</TD></TR><TR><TD CLASS="l">123</TD><TD>                                // EMF uses the unmodifiableCollection. Its a bit of a</TD></TR><TR><TD CLASS="l">124</TD><TD>                                // performance</TD></TR><TR><TD CLASS="l">125</TD><TD>                                // drain, but may want to leave in since</TD></TR><TR><TD CLASS="l">126</TD><TD>                                // it would &#34;fail fast&#34; if someone was trying to modify the</TD></TR><TR><TD CLASS="l">127</TD><TD>                                // list.</TD></TR><TR CLASS="z"><TD CLASS="l">128</TD><TD>                                return Collections.unmodifiableCollection(Arrays.asList(tempAdapters));</TD></TR><TR><TD CLASS="l">129</TD><TD>                                // return Arrays.asList(newAdapters);</TD></TR><TR><TD CLASS="l">130</TD><TD>                        }</TD></TR><TR><TD CLASS="l">131</TD><TD>                }</TD></TR><TR><TD CLASS="l">132</TD><TD>                else</TD></TR><TR CLASS="z"><TD CLASS="l">133</TD><TD>                        return Collections.EMPTY_LIST;</TD></TR><TR><TD CLASS="l">134</TD><TD>        }</TD></TR><TR><TD CLASS="l">135</TD><TD> </TD></TR><TR><TD CLASS="l">136</TD><TD>        private long getAdapterTimeCriteria() {</TD></TR><TR><TD CLASS="l">137</TD><TD>                // to &#34;re-get&#34; the property each time is a little awkward, but we</TD></TR><TR><TD CLASS="l"><A NAME="2">138</A></TD><TD>                // do it that way to avoid adding instance variable just for</TD></TR><TR><TD CLASS="l">139</TD><TD>                // debugging.</TD></TR><TR><TD CLASS="l">140</TD><TD>                // This method should only be called if debugAdapterNotifcationTime</TD></TR><TR><TD CLASS="l">141</TD><TD>                // is true.</TD></TR><TR CLASS="z"><TD CLASS="l">142</TD><TD>                final String criteriaStr = Platform.getDebugOption(&#34;org.eclipse.wst.sse.core/dom/adapter/notification/time/criteria&#34;); //$NON-NLS-1$</TD></TR><TR CLASS="z"><TD CLASS="l">143</TD><TD>                long criteria = -1;</TD></TR><TR CLASS="z"><TD CLASS="l">144</TD><TD>                if (criteriaStr != null) {</TD></TR><TR><TD CLASS="l">145</TD><TD>                        try {</TD></TR><TR CLASS="z"><TD CLASS="l">146</TD><TD>                                criteria = Long.parseLong(criteriaStr);</TD></TR><TR><TD CLASS="l">147</TD><TD>                        }</TD></TR><TR CLASS="z"><TD CLASS="l">148</TD><TD>                        catch (NumberFormatException e) {</TD></TR><TR><TD CLASS="l">149</TD><TD>                                // catch to be sure we don't burb in notification loop,</TD></TR><TR><TD CLASS="l">150</TD><TD>                                // but ignore, since just a debug aid</TD></TR><TR><TD CLASS="l">151</TD><TD>                        }</TD></TR><TR><TD CLASS="l">152</TD><TD>                }</TD></TR><TR CLASS="z"><TD CLASS="l"><A NAME="a">153</A></TD><TD>                return criteria;</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 INodeAdapter getExistingAdapter(Object type) {</TD></TR><TR CLASS="c"><TD CLASS="l">157</TD><TD>                INodeAdapter result = null;</TD></TR><TR CLASS="c"><TD CLASS="l">158</TD><TD>                for (int i = 0; i &lt; adapterCount; i++) {</TD></TR><TR CLASS="c"><TD CLASS="l">159</TD><TD>                        INodeAdapter a = fAdapters[i];</TD></TR><TR CLASS="c"><TD CLASS="l">160</TD><TD>                        if (a != null &amp;&amp; a.isAdapterForType(type)) {</TD></TR><TR CLASS="c"><TD CLASS="l">161</TD><TD>                                result = a;</TD></TR><TR CLASS="c"><TD CLASS="l">162</TD><TD>                                break;</TD></TR><TR><TD CLASS="l">163</TD><TD>                        }</TD></TR><TR><TD CLASS="l">164</TD><TD>                }</TD></TR><TR><TD CLASS="l">165</TD><TD>                // if we didn't find one in our list,</TD></TR><TR><TD CLASS="l">166</TD><TD>                // return the null result</TD></TR><TR CLASS="c"><TD CLASS="l">167</TD><TD>                return result;</TD></TR><TR><TD CLASS="l">168</TD><TD>        }</TD></TR><TR><TD CLASS="l">169</TD><TD> </TD></TR><TR><TD CLASS="l"><A NAME="5">170</A></TD><TD>        abstract public FactoryRegistry getFactoryRegistry();</TD></TR><TR><TD CLASS="l">171</TD><TD> </TD></TR><TR><TD CLASS="l">172</TD><TD>        public void notify(int eventType, Object changedFeature, Object oldValue, Object newValue, int pos) {</TD></TR><TR><TD CLASS="l">173</TD><TD> </TD></TR><TR CLASS="c"><TD CLASS="l">174</TD><TD>                if (fAdapters != null) {</TD></TR><TR CLASS="c"><TD CLASS="l">175</TD><TD>                        int localAdapterCount = 0;</TD></TR><TR CLASS="c"><TD CLASS="l">176</TD><TD>                        INodeAdapter[] localAdapters = null;</TD></TR><TR><TD CLASS="l">177</TD><TD> </TD></TR><TR><TD CLASS="l">178</TD><TD>                        // lock object while making local assignments</TD></TR><TR CLASS="p"><TD CLASS="l" TITLE="89% line coverage (25 out of 28 instructions)">179</TD><TD TITLE="89% line coverage (25 out of 28 instructions)">                        synchronized (this) {</TD></TR><TR CLASS="c"><TD CLASS="l">180</TD><TD>                                localAdapterCount = adapterCount;</TD></TR><TR CLASS="c"><TD CLASS="l">181</TD><TD>                                localAdapters = new INodeAdapter[localAdapterCount];</TD></TR><TR CLASS="c"><TD CLASS="l">182</TD><TD>                                System.arraycopy(fAdapters, 0, localAdapters, 0, localAdapterCount);</TD></TR><TR><TD CLASS="l">183</TD><TD>                        }</TD></TR><TR><TD CLASS="l">184</TD><TD> </TD></TR><TR CLASS="c"><TD CLASS="l">185</TD><TD>                        for (int i = 0; i &lt; localAdapterCount; i++) {</TD></TR><TR CLASS="c"><TD CLASS="l">186</TD><TD>                                INodeAdapter a = localAdapters[i];</TD></TR><TR><TD CLASS="l">187</TD><TD> </TD></TR><TR CLASS="c"><TD CLASS="l">188</TD><TD>                                if (Logger.DEBUG_ADAPTERNOTIFICATIONTIME) {</TD></TR><TR CLASS="z"><TD CLASS="l">189</TD><TD>                                        long getAdapterTimeCriteria = getAdapterTimeCriteria();</TD></TR><TR CLASS="z"><TD CLASS="l">190</TD><TD>                                        long startTime = System.currentTimeMillis();</TD></TR><TR><TD CLASS="l">191</TD><TD>                                        // ** keep this line identical with non-debug version!!</TD></TR><TR CLASS="z"><TD CLASS="l">192</TD><TD>                                        a.notifyChanged(this, eventType, changedFeature, oldValue, newValue, pos);</TD></TR><TR CLASS="z"><TD CLASS="l">193</TD><TD>                                        long notifyDuration = System.currentTimeMillis() - startTime;</TD></TR><TR CLASS="z"><TD CLASS="l">194</TD><TD>                                        if (getAdapterTimeCriteria &gt;= 0 &amp;&amp; notifyDuration &gt; getAdapterTimeCriteria) {</TD></TR><TR CLASS="z"><TD CLASS="l">195</TD><TD>                                                System.out.println(&#34;adapter notifyDuration: &#34; + notifyDuration + &#34;  class: &#34; + a.getClass()); //$NON-NLS-1$ //$NON-NLS-2$</TD></TR><TR><TD CLASS="l">196</TD><TD>                                        }</TD></TR><TR><TD CLASS="l">197</TD><TD>                                }</TD></TR><TR><TD CLASS="l">198</TD><TD>                                else {</TD></TR><TR><TD CLASS="l">199</TD><TD>                                        try {</TD></TR><TR><TD CLASS="l">200</TD><TD>                                                // ** keep this line identical with debug version!!</TD></TR><TR CLASS="c"><TD CLASS="l">201</TD><TD>                                                a.notifyChanged(this, eventType, changedFeature, oldValue, newValue, pos);</TD></TR><TR><TD CLASS="l">202</TD><TD>                                        }</TD></TR><TR CLASS="z"><TD CLASS="l">203</TD><TD>                                        catch (Exception e) {</TD></TR><TR><TD CLASS="l">204</TD><TD>                                                // Its important to &#34;keep going&#34;, since notifications</TD></TR><TR><TD CLASS="l">205</TD><TD>                                                // occur between an</TD></TR><TR><TD CLASS="l">206</TD><TD>                                                // aboutToChange event and a changed event -- the</TD></TR><TR><TD CLASS="l">207</TD><TD>                                                // changed event typically being require</TD></TR><TR><TD CLASS="l">208</TD><TD>                                                // to restore state, etc. So, we just log message, do</TD></TR><TR><TD CLASS="l">209</TD><TD>                                                // not re-throw it, but</TD></TR><TR><TD CLASS="l">210</TD><TD>                                                // typically the exception does indicate a serious</TD></TR><TR><TD CLASS="l">211</TD><TD>                                                // program error.</TD></TR><TR CLASS="z"><TD CLASS="l">212</TD><TD>                                                Logger.logException(&#34;A structured model client, &#34; + a + &#34; threw following exception during adapter notification (&#34; + INodeNotifier.EVENT_TYPE_STRINGS[eventType] + &#34; )&#34;, e); //$NON-NLS-1$ //$NON-NLS-2$ //$NON-NLS-3$</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> </TD></TR><TR><TD CLASS="l">216</TD><TD>                        }</TD></TR><TR><TD CLASS="l"><A NAME="4">217</A></TD><TD>                }</TD></TR><TR CLASS="c"><TD CLASS="l">218</TD><TD>        }</TD></TR><TR><TD CLASS="l">219</TD><TD> </TD></TR><TR><TD CLASS="l">220</TD><TD>        public synchronized void removeAdapter(INodeAdapter a) {</TD></TR><TR CLASS="z"><TD CLASS="l">221</TD><TD>                if (fAdapters == null || a == null)</TD></TR><TR CLASS="z"><TD CLASS="l">222</TD><TD>                        return;</TD></TR><TR CLASS="z"><TD CLASS="l">223</TD><TD>                int newIndex = 0;</TD></TR><TR CLASS="z"><TD CLASS="l">224</TD><TD>                INodeAdapter[] newAdapters = new INodeAdapter[fAdapters.length];</TD></TR><TR CLASS="z"><TD CLASS="l">225</TD><TD>                int oldAdapterCount = adapterCount;</TD></TR><TR CLASS="z"><TD CLASS="l">226</TD><TD>                boolean found = false;</TD></TR><TR CLASS="z"><TD CLASS="l">227</TD><TD>                for (int oldIndex = 0; oldIndex &lt; oldAdapterCount; oldIndex++) {</TD></TR><TR CLASS="z"><TD CLASS="l">228</TD><TD>                        INodeAdapter candidate = fAdapters[oldIndex];</TD></TR><TR CLASS="z"><TD CLASS="l">229</TD><TD>                        if (a == candidate) {</TD></TR><TR CLASS="z"><TD CLASS="l">230</TD><TD>                                adapterCount--;</TD></TR><TR CLASS="z"><TD CLASS="l">231</TD><TD>                                found = true;</TD></TR><TR><TD CLASS="l">232</TD><TD>                        }</TD></TR><TR><TD CLASS="l">233</TD><TD>                        else</TD></TR><TR CLASS="z"><TD CLASS="l">234</TD><TD>                                newAdapters[newIndex++] = fAdapters[oldIndex];</TD></TR><TR><TD CLASS="l">235</TD><TD>                }</TD></TR><TR CLASS="z"><TD CLASS="l">236</TD><TD>                if (found)</TD></TR><TR CLASS="z"><TD CLASS="l">237</TD><TD>                        fAdapters = newAdapters;</TD></TR><TR CLASS="z"><TD CLASS="l">238</TD><TD>        }</TD></TR><TR><TD CLASS="l">239</TD><TD> </TD></TR><TR><TD CLASS="l">240</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="ae.html">org.eclipse.wst.sse.core.internal.provisional</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>