blob: 4f5b99c5875561b301b4b317d3c56f9a08b62c45 [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="74.html">org.eclipse.wst.sse.core.internal.tasks</A>]</TD></TR></TABLE><H2>COVERAGE SUMMARY FOR SOURCE FILE [<SPAN CLASS="in">TaskScanningJob.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>TaskScanningJob.java</TD><TD>100% (1/1)</TD><TD CLASS="h">33%  (3/9)</TD><TD CLASS="h">15%  (73/495)</TD><TD CLASS="h">14%  (16/112)</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">TaskScanningJob</A></TD><TD>100% (1/1)</TD><TD CLASS="h">33%  (3/9)</TD><TD CLASS="h">15%  (73/495)</TD><TD CLASS="h">14%  (16/112)</TD></TR><TR><TD CLASS="f"><A HREF="#1">addProject (IProject): 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="#2">cleanupRememberedProjectList (String): void</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/108)</TD><TD CLASS="h">0%   (0/18)</TD></TR><TR><TD CLASS="f"><A HREF="#3">frameworkIsShuttingDown (): boolean</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/20)</TD><TD CLASS="h">0%   (0/4)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#4">projectHasNotBeenFullyScanned (IResource): boolean</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/43)</TD><TD CLASS="h">0%   (0/9)</TD></TR><TR><TD CLASS="f"><A HREF="#5">retrieveQueue (): List</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="#6">run (IProgressMonitor): IStatus</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/175)</TD><TD CLASS="h">0%   (0/41)</TD></TR><TR><TD CLASS="f"><A HREF="#7">addProjectDelta (IResourceDelta): void</A></TD><TD> </TD><TD>100% (1/1)</TD><TD CLASS="h">24%  (13/54)</TD><TD CLASS="h">21%  (4/19)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#0">TaskScanningJob (): void</A></TD><TD> </TD><TD>100% (1/1)</TD><TD>100% (29/29)</TD><TD>100% (9/9)</TD></TR><TR><TD CLASS="f"><A HREF="#9">isEnabledOnProject (IProject): boolean</A></TD><TD> </TD><TD>100% (1/1)</TD><TD>100% (31/31)</TD><TD>100% (3/3)</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, 2006 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> *     </TD></TR><TR><TD CLASS="l">11</TD><TD> *******************************************************************************/</TD></TR><TR><TD CLASS="l">12</TD><TD>package org.eclipse.wst.sse.core.internal.tasks;</TD></TR><TR><TD CLASS="l">13</TD><TD> </TD></TR><TR><TD CLASS="l">14</TD><TD>import java.util.ArrayList;</TD></TR><TR><TD CLASS="l">15</TD><TD>import java.util.List;</TD></TR><TR><TD CLASS="l">16</TD><TD> </TD></TR><TR><TD CLASS="l">17</TD><TD>import org.eclipse.core.resources.IProject;</TD></TR><TR><TD CLASS="l">18</TD><TD>import org.eclipse.core.resources.IResource;</TD></TR><TR><TD CLASS="l">19</TD><TD>import org.eclipse.core.resources.IResourceDelta;</TD></TR><TR><TD CLASS="l">20</TD><TD>import org.eclipse.core.resources.ProjectScope;</TD></TR><TR><TD CLASS="l">21</TD><TD>import org.eclipse.core.resources.ResourcesPlugin;</TD></TR><TR><TD CLASS="l">22</TD><TD>import org.eclipse.core.runtime.IProgressMonitor;</TD></TR><TR><TD CLASS="l">23</TD><TD>import org.eclipse.core.runtime.IStatus;</TD></TR><TR><TD CLASS="l">24</TD><TD>import org.eclipse.core.runtime.MultiStatus;</TD></TR><TR><TD CLASS="l">25</TD><TD>import org.eclipse.core.runtime.Platform;</TD></TR><TR><TD CLASS="l">26</TD><TD>import org.eclipse.core.runtime.Status;</TD></TR><TR><TD CLASS="l">27</TD><TD>import org.eclipse.core.runtime.SubProgressMonitor;</TD></TR><TR><TD CLASS="l">28</TD><TD>import org.eclipse.core.runtime.jobs.Job;</TD></TR><TR><TD CLASS="l">29</TD><TD>import org.eclipse.core.runtime.preferences.DefaultScope;</TD></TR><TR><TD CLASS="l">30</TD><TD>import org.eclipse.core.runtime.preferences.IPreferencesService;</TD></TR><TR><TD CLASS="l">31</TD><TD>import org.eclipse.core.runtime.preferences.IScopeContext;</TD></TR><TR><TD CLASS="l">32</TD><TD>import org.eclipse.core.runtime.preferences.InstanceScope;</TD></TR><TR><TD CLASS="l">33</TD><TD>import org.eclipse.wst.sse.core.internal.Logger;</TD></TR><TR><TD CLASS="l">34</TD><TD>import org.eclipse.wst.sse.core.internal.SSECoreMessages;</TD></TR><TR><TD CLASS="l">35</TD><TD>import org.eclipse.wst.sse.core.internal.SSECorePlugin;</TD></TR><TR><TD CLASS="l">36</TD><TD>import org.eclipse.wst.sse.core.utils.StringUtils;</TD></TR><TR><TD CLASS="l">37</TD><TD>import org.osgi.framework.Bundle;</TD></TR><TR><TD CLASS="l">38</TD><TD> </TD></TR><TR><TD CLASS="l">39</TD><TD>/**</TD></TR><TR><TD CLASS="l">40</TD><TD> * Queueing Job for processing deltas and projects.</TD></TR><TR><TD CLASS="l">41</TD><TD> */</TD></TR><TR><TD CLASS="l">42</TD><TD>class TaskScanningJob extends Job {</TD></TR><TR><TD CLASS="l">43</TD><TD>        static final int JOB_DELAY_DELTA = 400;</TD></TR><TR><TD CLASS="l">44</TD><TD>        private static final int JOB_DELAY_PROJECT = 2000;</TD></TR><TR><TD CLASS="l">45</TD><TD>        static final String TASK_TAG_PROJECTS_ALREADY_SCANNED = &#34;task-tag-projects-already-scanned&#34;; //$NON-NLS-1$</TD></TR><TR CLASS="c"><TD CLASS="l">46</TD><TD>        private List fQueue = null;</TD></TR><TR><TD CLASS="l">47</TD><TD> </TD></TR><TR><TD CLASS="l"><A NAME="0">48</A></TD><TD>        /** symbolic name for OSGI framework */</TD></TR><TR CLASS="c"><TD CLASS="l">49</TD><TD>        private final String OSGI_FRAMEWORK_ID = &#34;org.eclipse.osgi&#34;; //$NON-NLS-1$</TD></TR><TR><TD CLASS="l">50</TD><TD> </TD></TR><TR><TD CLASS="l">51</TD><TD>        TaskScanningJob() {</TD></TR><TR CLASS="c"><TD CLASS="l">52</TD><TD>                super(SSECoreMessages.TaskScanner_0);</TD></TR><TR CLASS="c"><TD CLASS="l">53</TD><TD>                fQueue = new ArrayList();</TD></TR><TR CLASS="c"><TD CLASS="l">54</TD><TD>                setPriority(Job.DECORATE);</TD></TR><TR CLASS="c"><TD CLASS="l">55</TD><TD>                setSystem(true);</TD></TR><TR CLASS="c"><TD CLASS="l">56</TD><TD>                setUser(false);</TD></TR><TR><TD CLASS="l">57</TD><TD> </TD></TR><TR CLASS="c"><TD CLASS="l"><A NAME="7">58</A></TD><TD>                SSECorePlugin.getDefault().getPluginPreferences().setDefault(TASK_TAG_PROJECTS_ALREADY_SCANNED, &#34;&#34;); //$NON-NLS-1$</TD></TR><TR CLASS="c"><TD CLASS="l">59</TD><TD>        }</TD></TR><TR><TD CLASS="l">60</TD><TD> </TD></TR><TR><TD CLASS="l">61</TD><TD>        synchronized void addProjectDelta(IResourceDelta delta) {</TD></TR><TR CLASS="c"><TD CLASS="l">62</TD><TD>                IResource projectResource = delta.getResource();</TD></TR><TR><TD CLASS="l">63</TD><TD> </TD></TR><TR CLASS="c"><TD CLASS="l">64</TD><TD>                if (projectResource.getType() == IResource.PROJECT) {</TD></TR><TR CLASS="c"><TD CLASS="l">65</TD><TD>                        if (isEnabledOnProject((IProject) projectResource)) {</TD></TR><TR CLASS="z"><TD CLASS="l">66</TD><TD>                                fQueue.add(delta);</TD></TR><TR CLASS="z"><TD CLASS="l">67</TD><TD>                                if (Logger.DEBUG_TASKSJOB) {</TD></TR><TR CLASS="z"><TD CLASS="l">68</TD><TD>                                        String kind = null;</TD></TR><TR CLASS="z"><TD CLASS="l">69</TD><TD>                                        switch (delta.getKind()) {</TD></TR><TR><TD CLASS="l">70</TD><TD>                                                case IResourceDelta.ADDED :</TD></TR><TR CLASS="z"><TD CLASS="l">71</TD><TD>                                                        kind = &#34; [IResourceDelta.ADDED]&#34;; //$NON-NLS-1$</TD></TR><TR CLASS="z"><TD CLASS="l">72</TD><TD>                                                        break;</TD></TR><TR><TD CLASS="l">73</TD><TD>                                                case IResourceDelta.CHANGED :</TD></TR><TR CLASS="z"><TD CLASS="l">74</TD><TD>                                                        kind = &#34; [IResourceDelta.CHANGED]&#34;; //$NON-NLS-1$</TD></TR><TR CLASS="z"><TD CLASS="l">75</TD><TD>                                                        break;</TD></TR><TR><TD CLASS="l">76</TD><TD>                                                case IResourceDelta.REMOVED :</TD></TR><TR CLASS="z"><TD CLASS="l">77</TD><TD>                                                        kind = &#34; [IResourceDelta.REMOVED]&#34;; //$NON-NLS-1$</TD></TR><TR CLASS="z"><TD CLASS="l">78</TD><TD>                                                        break;</TD></TR><TR><TD CLASS="l">79</TD><TD>                                                case IResourceDelta.ADDED_PHANTOM :</TD></TR><TR CLASS="z"><TD CLASS="l">80</TD><TD>                                                        kind = &#34; [IResourceDelta.ADDED_PHANTOM]&#34;; //$NON-NLS-1$</TD></TR><TR CLASS="z"><TD CLASS="l">81</TD><TD>                                                        break;</TD></TR><TR><TD CLASS="l">82</TD><TD>                                                case IResourceDelta.REMOVED_PHANTOM :</TD></TR><TR CLASS="z"><TD CLASS="l">83</TD><TD>                                                        kind = &#34; [IResourceDelta.REMOVED_PHANTOM]&#34;; //$NON-NLS-1$</TD></TR><TR><TD CLASS="l">84</TD><TD>                                                        break;</TD></TR><TR><TD CLASS="l">85</TD><TD>                                        }</TD></TR><TR CLASS="z"><TD CLASS="l">86</TD><TD>                                        System.out.println(&#34;Adding delta &#34; + delta.getFullPath() + kind); //$NON-NLS-1$</TD></TR><TR><TD CLASS="l">87</TD><TD>                                }</TD></TR><TR CLASS="z"><TD CLASS="l">88</TD><TD>                                schedule(JOB_DELAY_DELTA);</TD></TR><TR><TD CLASS="l">89</TD><TD>                        }</TD></TR><TR><TD CLASS="l"><A NAME="1">90</A></TD><TD>                }</TD></TR><TR CLASS="c"><TD CLASS="l">91</TD><TD>        }</TD></TR><TR><TD CLASS="l">92</TD><TD> </TD></TR><TR><TD CLASS="l">93</TD><TD>        synchronized void addProject(IProject project) {</TD></TR><TR CLASS="z"><TD CLASS="l">94</TD><TD>                if (projectHasNotBeenFullyScanned(project)) {</TD></TR><TR CLASS="z"><TD CLASS="l">95</TD><TD>                        fQueue.add(project);</TD></TR><TR CLASS="z"><TD CLASS="l">96</TD><TD>                        if (Logger.DEBUG_TASKSJOB) {</TD></TR><TR CLASS="z"><TD CLASS="l">97</TD><TD>                                System.out.println(&#34;Adding project &#34; + project.getName()); //$NON-NLS-1$</TD></TR><TR><TD CLASS="l">98</TD><TD>                        }</TD></TR><TR CLASS="z"><TD CLASS="l">99</TD><TD>                        schedule(JOB_DELAY_PROJECT);</TD></TR><TR><TD CLASS="l">100</TD><TD>                }</TD></TR><TR CLASS="z"><TD CLASS="l">101</TD><TD>        }</TD></TR><TR><TD CLASS="l">102</TD><TD> </TD></TR><TR><TD CLASS="l">103</TD><TD>        /**</TD></TR><TR><TD CLASS="l">104</TD><TD>         * A check to see if the OSGI framework is shutting down.</TD></TR><TR><TD CLASS="l">105</TD><TD>         * </TD></TR><TR><TD CLASS="l">106</TD><TD>         * @return true if the System Bundle is stopped (ie. the framework is</TD></TR><TR><TD CLASS="l">107</TD><TD>         *         shutting down)</TD></TR><TR><TD CLASS="l">108</TD><TD>         */</TD></TR><TR><TD CLASS="l">109</TD><TD>        boolean frameworkIsShuttingDown() {</TD></TR><TR><TD CLASS="l"><A NAME="3">110</A></TD><TD>                // in the Framework class there's a note:</TD></TR><TR><TD CLASS="l">111</TD><TD>                // set the state of the System Bundle to STOPPING.</TD></TR><TR><TD CLASS="l">112</TD><TD>                // this must be done first according to section 4.19.2 from the OSGi</TD></TR><TR><TD CLASS="l">113</TD><TD>                // R3 spec.</TD></TR><TR CLASS="z"><TD CLASS="l">114</TD><TD>                boolean shuttingDown = !Platform.isRunning() || Platform.getBundle(OSGI_FRAMEWORK_ID).getState() == Bundle.STOPPING;</TD></TR><TR CLASS="z"><TD CLASS="l">115</TD><TD>                if (Logger.DEBUG_TASKSJOB &amp;&amp; shuttingDown) {</TD></TR><TR CLASS="z"><TD CLASS="l">116</TD><TD>                        System.out.println(&#34;TaskScanningJob: system is shutting down!&#34;); //$NON-NLS-1$</TD></TR><TR><TD CLASS="l">117</TD><TD>                }</TD></TR><TR CLASS="z"><TD CLASS="l"><A NAME="9">118</A></TD><TD>                return shuttingDown;</TD></TR><TR><TD CLASS="l">119</TD><TD>        }</TD></TR><TR><TD CLASS="l">120</TD><TD>        </TD></TR><TR><TD CLASS="l">121</TD><TD>        private boolean isEnabledOnProject(IProject p) {</TD></TR><TR CLASS="c"><TD CLASS="l">122</TD><TD>                IPreferencesService preferencesService = Platform.getPreferencesService();</TD></TR><TR CLASS="c"><TD CLASS="l">123</TD><TD>                IScopeContext[] lookupOrder = new IScopeContext[]{new ProjectScope(p), new InstanceScope(), new DefaultScope()};</TD></TR><TR CLASS="c"><TD CLASS="l"><A NAME="4">124</A></TD><TD>                return preferencesService.getBoolean(TaskTagPreferenceKeys.TASK_TAG_NODE, TaskTagPreferenceKeys.TASK_TAG_ENABLE, false, lookupOrder);</TD></TR><TR><TD CLASS="l">125</TD><TD>        }</TD></TR><TR><TD CLASS="l">126</TD><TD> </TD></TR><TR><TD CLASS="l">127</TD><TD>        private boolean projectHasNotBeenFullyScanned(IResource project) {</TD></TR><TR CLASS="z"><TD CLASS="l">128</TD><TD>                String[] projectsScanned = StringUtils.unpack(SSECorePlugin.getDefault().getPluginPreferences().getString(TASK_TAG_PROJECTS_ALREADY_SCANNED));</TD></TR><TR><TD CLASS="l">129</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">130</TD><TD>                boolean shouldScan = true;</TD></TR><TR CLASS="z"><TD CLASS="l">131</TD><TD>                String name = project.getName();</TD></TR><TR CLASS="z"><TD CLASS="l">132</TD><TD>                for (int j = 0; shouldScan &amp;&amp; j &lt; projectsScanned.length; j++) {</TD></TR><TR CLASS="z"><TD CLASS="l">133</TD><TD>                        if (projectsScanned[j].equals(name)) {</TD></TR><TR CLASS="z"><TD CLASS="l">134</TD><TD>                                if (Logger.DEBUG_TASKSJOB)</TD></TR><TR CLASS="z"><TD CLASS="l">135</TD><TD>                                        System.out.println(&#34;Scanning Job skipping &#34; + project.getName()); //$NON-NLS-1$</TD></TR><TR CLASS="z"><TD CLASS="l">136</TD><TD>                                shouldScan = false;</TD></TR><TR><TD CLASS="l">137</TD><TD>                        }</TD></TR><TR><TD CLASS="l">138</TD><TD>                }</TD></TR><TR CLASS="z"><TD CLASS="l"><A NAME="5">139</A></TD><TD>                return shouldScan;</TD></TR><TR><TD CLASS="l">140</TD><TD>        }</TD></TR><TR><TD CLASS="l">141</TD><TD> </TD></TR><TR><TD CLASS="l">142</TD><TD>        synchronized List retrieveQueue() {</TD></TR><TR CLASS="z"><TD CLASS="l">143</TD><TD>                List queue = fQueue;</TD></TR><TR CLASS="z"><TD CLASS="l">144</TD><TD>                fQueue = new ArrayList();</TD></TR><TR CLASS="z"><TD CLASS="l"><A NAME="6">145</A></TD><TD>                return queue;</TD></TR><TR><TD CLASS="l">146</TD><TD>        }</TD></TR><TR><TD CLASS="l">147</TD><TD> </TD></TR><TR><TD CLASS="l">148</TD><TD>        protected IStatus run(IProgressMonitor monitor) {</TD></TR><TR CLASS="z"><TD CLASS="l">149</TD><TD>                if (frameworkIsShuttingDown())</TD></TR><TR CLASS="z"><TD CLASS="l">150</TD><TD>                        return Status.CANCEL_STATUS;</TD></TR><TR><TD CLASS="l">151</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">152</TD><TD>                cleanupRememberedProjectList(TASK_TAG_PROJECTS_ALREADY_SCANNED);</TD></TR><TR><TD CLASS="l">153</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">154</TD><TD>                IStatus status = null;</TD></TR><TR CLASS="z"><TD CLASS="l">155</TD><TD>                List currentQueue = retrieveQueue();</TD></TR><TR CLASS="z"><TD CLASS="l">156</TD><TD>                List errors = null;</TD></TR><TR CLASS="z"><TD CLASS="l">157</TD><TD>                int ticks = currentQueue.size();</TD></TR><TR CLASS="z"><TD CLASS="l">158</TD><TD>                String taskName = null;</TD></TR><TR CLASS="z"><TD CLASS="l">159</TD><TD>                if (Logger.DEBUG_TASKSJOB) {</TD></TR><TR CLASS="z"><TD CLASS="l">160</TD><TD>                        taskName = SSECoreMessages.TaskScanningJob_0 + &#34; (&#34; + ticks + &#34; work items)&#34;; //$NON-NLS-1$ //$NON-NLS-2$</TD></TR><TR><TD CLASS="l">161</TD><TD>                }</TD></TR><TR><TD CLASS="l">162</TD><TD>                else {</TD></TR><TR CLASS="z"><TD CLASS="l">163</TD><TD>                        taskName = SSECoreMessages.TaskScanningJob_0;</TD></TR><TR><TD CLASS="l">164</TD><TD>                }</TD></TR><TR CLASS="z"><TD CLASS="l">165</TD><TD>                monitor.beginTask(taskName, ticks);</TD></TR><TR><TD CLASS="l">166</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">167</TD><TD>                IProgressMonitor scanMonitor = null;</TD></TR><TR CLASS="z"><TD CLASS="l">168</TD><TD>                while (!currentQueue.isEmpty()) {</TD></TR><TR CLASS="z"><TD CLASS="l">169</TD><TD>                        Object o = currentQueue.remove(0);</TD></TR><TR CLASS="z"><TD CLASS="l">170</TD><TD>                        if (frameworkIsShuttingDown())</TD></TR><TR CLASS="z"><TD CLASS="l">171</TD><TD>                                return Status.CANCEL_STATUS;</TD></TR><TR><TD CLASS="l">172</TD><TD>                        try {</TD></TR><TR CLASS="z"><TD CLASS="l">173</TD><TD>                                scanMonitor = new SubProgressMonitor(monitor, 1, SubProgressMonitor.PREPEND_MAIN_LABEL_TO_SUBTASK);</TD></TR><TR CLASS="z"><TD CLASS="l">174</TD><TD>                                if (o instanceof IResourceDelta) {</TD></TR><TR CLASS="z"><TD CLASS="l">175</TD><TD>                                        WorkspaceTaskScanner.getInstance().scan((IResourceDelta) o, scanMonitor);</TD></TR><TR><TD CLASS="l">176</TD><TD>                                }</TD></TR><TR CLASS="z"><TD CLASS="l">177</TD><TD>                                else if (o instanceof IProject) {</TD></TR><TR CLASS="z"><TD CLASS="l">178</TD><TD>                                        WorkspaceTaskScanner.getInstance().scan((IProject) o, scanMonitor);</TD></TR><TR CLASS="z"><TD CLASS="l">179</TD><TD>                                        if(!scanMonitor.isCanceled() ) {</TD></TR><TR CLASS="z"><TD CLASS="l">180</TD><TD>                                                String[] projectsPreviouslyScanned = StringUtils.unpack(SSECorePlugin.getDefault().getPluginPreferences().getString(TASK_TAG_PROJECTS_ALREADY_SCANNED));</TD></TR><TR CLASS="z"><TD CLASS="l">181</TD><TD>                                                String[] updatedProjects = new String[projectsPreviouslyScanned.length + 1];</TD></TR><TR CLASS="z"><TD CLASS="l">182</TD><TD>                                                updatedProjects[projectsPreviouslyScanned.length] = ((IResource) o).getName();</TD></TR><TR CLASS="z"><TD CLASS="l">183</TD><TD>                                                System.arraycopy(projectsPreviouslyScanned, 0, updatedProjects, 0, projectsPreviouslyScanned.length);</TD></TR><TR CLASS="z"><TD CLASS="l">184</TD><TD>                                                SSECorePlugin.getDefault().getPluginPreferences().setValue(TASK_TAG_PROJECTS_ALREADY_SCANNED, StringUtils.pack(updatedProjects));</TD></TR><TR><TD CLASS="l">185</TD><TD>                                        }</TD></TR><TR><TD CLASS="l">186</TD><TD>                                }</TD></TR><TR><TD CLASS="l">187</TD><TD>                        }</TD></TR><TR CLASS="z"><TD CLASS="l">188</TD><TD>                        catch (Exception e) {</TD></TR><TR CLASS="z"><TD CLASS="l">189</TD><TD>                                if (errors == null) {</TD></TR><TR CLASS="z"><TD CLASS="l">190</TD><TD>                                        errors = new ArrayList();</TD></TR><TR><TD CLASS="l">191</TD><TD>                                }</TD></TR><TR CLASS="z"><TD CLASS="l">192</TD><TD>                                errors.add(new Status(IStatus.ERROR, SSECorePlugin.ID, IStatus.ERROR, &#34;&#34;, e)); //$NON-NLS-1$</TD></TR><TR><TD CLASS="l">193</TD><TD>                        }</TD></TR><TR><TD CLASS="l">194</TD><TD>                }</TD></TR><TR CLASS="z"><TD CLASS="l">195</TD><TD>                monitor.done();</TD></TR><TR><TD CLASS="l">196</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">197</TD><TD>                if (errors == null || errors.isEmpty()) {</TD></TR><TR CLASS="z"><TD CLASS="l">198</TD><TD>                        status = Status.OK_STATUS;</TD></TR><TR><TD CLASS="l">199</TD><TD>                }</TD></TR><TR><TD CLASS="l">200</TD><TD>                else {</TD></TR><TR CLASS="z"><TD CLASS="l">201</TD><TD>                        if (errors.size() == 1) {</TD></TR><TR CLASS="z"><TD CLASS="l">202</TD><TD>                                status = (IStatus) errors.get(0);</TD></TR><TR><TD CLASS="l">203</TD><TD>                        }</TD></TR><TR><TD CLASS="l">204</TD><TD>                        else {</TD></TR><TR CLASS="z"><TD CLASS="l">205</TD><TD>                                IStatus[] statii = (IStatus[]) errors.toArray(new IStatus[errors.size()]);</TD></TR><TR CLASS="z"><TD CLASS="l">206</TD><TD>                                status = new MultiStatus(SSECorePlugin.ID, IStatus.ERROR, statii, SSECoreMessages.TaskScanningJob_1, null);</TD></TR><TR><TD CLASS="l">207</TD><TD>                        }</TD></TR><TR><TD CLASS="l">208</TD><TD>                }</TD></TR><TR><TD CLASS="l">209</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">210</TD><TD>                SSECorePlugin.getDefault().savePluginPreferences();</TD></TR><TR CLASS="z"><TD CLASS="l"><A NAME="2">211</A></TD><TD>                return status;</TD></TR><TR><TD CLASS="l">212</TD><TD>        }</TD></TR><TR><TD CLASS="l">213</TD><TD> </TD></TR><TR><TD CLASS="l">214</TD><TD>        private void cleanupRememberedProjectList(String preferenceName) {</TD></TR><TR CLASS="z"><TD CLASS="l">215</TD><TD>                String[] rememberedProjectNames = StringUtils.unpack(SSECorePlugin.getDefault().getPluginPreferences().getString(preferenceName));</TD></TR><TR CLASS="z"><TD CLASS="l">216</TD><TD>                IResource[] workspaceProjects = ResourcesPlugin.getWorkspace().getRoot().getProjects();</TD></TR><TR CLASS="z"><TD CLASS="l">217</TD><TD>                String[] projectNames = new String[workspaceProjects.length];</TD></TR><TR CLASS="z"><TD CLASS="l">218</TD><TD>                for (int i = 0; i &lt; projectNames.length; i++) {</TD></TR><TR CLASS="z"><TD CLASS="l">219</TD><TD>                        projectNames[i] = workspaceProjects[i].getName();</TD></TR><TR><TD CLASS="l">220</TD><TD>                }</TD></TR><TR><TD CLASS="l">221</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">222</TD><TD>                List projectNamesToRemember = new ArrayList(rememberedProjectNames.length);</TD></TR><TR CLASS="z"><TD CLASS="l">223</TD><TD>                for (int i = 0; i &lt; rememberedProjectNames.length; i++) {</TD></TR><TR CLASS="z"><TD CLASS="l">224</TD><TD>                        boolean rememberedProjectExists = false;</TD></TR><TR CLASS="z"><TD CLASS="l">225</TD><TD>                        for (int j = 0; !rememberedProjectExists &amp;&amp; j &lt; projectNames.length; j++) {</TD></TR><TR CLASS="z"><TD CLASS="l">226</TD><TD>                                if (rememberedProjectNames[i].equals(projectNames[j])) {</TD></TR><TR CLASS="z"><TD CLASS="l">227</TD><TD>                                        rememberedProjectExists = true;</TD></TR><TR><TD CLASS="l">228</TD><TD>                                }</TD></TR><TR><TD CLASS="l">229</TD><TD>                        }</TD></TR><TR CLASS="z"><TD CLASS="l">230</TD><TD>                        if (rememberedProjectExists) {</TD></TR><TR CLASS="z"><TD CLASS="l">231</TD><TD>                                projectNamesToRemember.add(rememberedProjectNames[i]);</TD></TR><TR><TD CLASS="l">232</TD><TD>                        }</TD></TR><TR CLASS="z"><TD CLASS="l">233</TD><TD>                        else if (Logger.DEBUG_TASKSJOB) {</TD></TR><TR CLASS="z"><TD CLASS="l">234</TD><TD>                                System.out.println(&#34;Removing &#34; + rememberedProjectNames[i] + &#34; removed from &#34; + preferenceName); //$NON-NLS-1$ //$NON-NLS-2$</TD></TR><TR><TD CLASS="l">235</TD><TD>                        }</TD></TR><TR><TD CLASS="l">236</TD><TD>                }</TD></TR><TR><TD CLASS="l">237</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">238</TD><TD>                if (projectNamesToRemember.size() != rememberedProjectNames.length) {</TD></TR><TR CLASS="z"><TD CLASS="l">239</TD><TD>                        SSECorePlugin.getDefault().getPluginPreferences().setValue(preferenceName, StringUtils.pack((String[]) projectNamesToRemember.toArray(new String[projectNamesToRemember.size()])));</TD></TR><TR><TD CLASS="l">240</TD><TD>                }</TD></TR><TR CLASS="z"><TD CLASS="l">241</TD><TD>        }</TD></TR><TR><TD CLASS="l">242</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="74.html">org.eclipse.wst.sse.core.internal.tasks</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>