<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">WorkspaceTaskScanner.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>WorkspaceTaskScanner.java</TD><TD CLASS="h">0%   (0/2)</TD><TD CLASS="h">0%   (0/15)</TD><TD CLASS="h">0%   (0/1231)</TD><TD CLASS="h">0%   (0/236)</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">WorkspaceTaskScanner</A></TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/13)</TD><TD CLASS="h">0%   (0/1061)</TD><TD CLASS="h">0%   (0/208)</TD></TR><TR><TD CLASS="f"><A HREF="#0">&lt;static initializer&gt;</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/3)</TD><TD CLASS="h">0%   (0/2)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#2">WorkspaceTaskScanner (): void</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/34)</TD><TD CLASS="h">0%   (0/11)</TD></TR><TR><TD CLASS="f"><A HREF="#3">detectContentTypes (IResource): IContentType []</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/91)</TD><TD CLASS="h">0%   (0/18)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#4">getInstance (): WorkspaceTaskScanner</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><TD CLASS="f"><A HREF="#5">getProject (IResource): IProject</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/15)</TD><TD CLASS="h">0%   (0/5)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#6">init (IResource): boolean</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/243)</TD><TD CLASS="h">0%   (0/41)</TD></TR><TR><TD CLASS="f"><A HREF="#7">internalScan (IProject, IResource, IProgressMonitor): void</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/87)</TD><TD CLASS="h">0%   (0/15)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#8">internalScan (IResourceDelta, IProgressMonitor): void</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/116)</TD><TD CLASS="h">0%   (0/19)</TD></TR><TR><TD CLASS="f"><A HREF="#9">replaceTaskMarkers (IFile, String [], Map [], IProgressMonitor): void</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/34)</TD><TD CLASS="h">0%   (0/9)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#a">scan (IProject, IProgressMonitor): void</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/78)</TD><TD CLASS="h">0%   (0/16)</TD></TR><TR><TD CLASS="f"><A HREF="#b">scan (IResourceDelta, IProgressMonitor): void</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/42)</TD><TD CLASS="h">0%   (0/10)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#c">scanFile (IProject, TaskTag [], IFile, IProgressMonitor): void</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/280)</TD><TD CLASS="h">0%   (0/53)</TD></TR><TR><TD CLASS="f"><A HREF="#d">shutdownDelegates (IProject): void</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/30)</TD><TD CLASS="h">0%   (0/6)</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="#e">WorkspaceTaskScanner$1</A></TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/2)</TD><TD CLASS="h">0%   (0/170)</TD><TD CLASS="h">0%   (0/29)</TD></TR><TR><TD CLASS="f"><A HREF="#e">WorkspaceTaskScanner$1 (WorkspaceTaskScanner, String [], IFile, Map [], IFile...</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/18)</TD><TD CLASS="h">0%   (0/2)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#10">run (IProgressMonitor): void</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/152)</TD><TD CLASS="h">0%   (0/27)</TD></TR></TABLE><P></P><TABLE CLASS="s" CELLSPACING="0" WIDTH="100%"><TR CLASS="z"><TD CLASS="l">1</TD><TD>/*******************************************************************************</TD></TR><TR><TD CLASS="l">2</TD><TD> * Copyright (c) 2001, 2008 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.tasks;</TD></TR><TR><TD CLASS="l">14</TD><TD> </TD></TR><TR><TD CLASS="l">15</TD><TD>import java.util.ArrayList;</TD></TR><TR><TD CLASS="l">16</TD><TD>import java.util.HashSet;</TD></TR><TR><TD CLASS="l">17</TD><TD>import java.util.List;</TD></TR><TR><TD CLASS="l">18</TD><TD>import java.util.Map;</TD></TR><TR><TD CLASS="l">19</TD><TD>import java.util.Set;</TD></TR><TR><TD CLASS="l">20</TD><TD> </TD></TR><TR><TD CLASS="l">21</TD><TD>import org.eclipse.core.resources.IContainer;</TD></TR><TR><TD CLASS="l">22</TD><TD>import org.eclipse.core.resources.IFile;</TD></TR><TR><TD CLASS="l">23</TD><TD>import org.eclipse.core.resources.IMarker;</TD></TR><TR><TD CLASS="l">24</TD><TD>import org.eclipse.core.resources.IProject;</TD></TR><TR><TD CLASS="l">25</TD><TD>import org.eclipse.core.resources.IResource;</TD></TR><TR><TD CLASS="l">26</TD><TD>import org.eclipse.core.resources.IResourceDelta;</TD></TR><TR><TD CLASS="l">27</TD><TD>import org.eclipse.core.resources.IWorkspace;</TD></TR><TR><TD CLASS="l">28</TD><TD>import org.eclipse.core.resources.IWorkspaceRunnable;</TD></TR><TR><TD CLASS="l">29</TD><TD>import org.eclipse.core.resources.ProjectScope;</TD></TR><TR><TD CLASS="l">30</TD><TD>import org.eclipse.core.resources.ResourcesPlugin;</TD></TR><TR><TD CLASS="l">31</TD><TD>import org.eclipse.core.runtime.CoreException;</TD></TR><TR><TD CLASS="l">32</TD><TD>import org.eclipse.core.runtime.IProgressMonitor;</TD></TR><TR><TD CLASS="l">33</TD><TD>import org.eclipse.core.runtime.OperationCanceledException;</TD></TR><TR><TD CLASS="l">34</TD><TD>import org.eclipse.core.runtime.Platform;</TD></TR><TR><TD CLASS="l">35</TD><TD>import org.eclipse.core.runtime.SubProgressMonitor;</TD></TR><TR><TD CLASS="l">36</TD><TD>import org.eclipse.core.runtime.content.IContentDescription;</TD></TR><TR><TD CLASS="l">37</TD><TD>import org.eclipse.core.runtime.content.IContentType;</TD></TR><TR><TD CLASS="l">38</TD><TD>import org.eclipse.core.runtime.content.IContentTypeManager;</TD></TR><TR><TD CLASS="l">39</TD><TD>import org.eclipse.core.runtime.preferences.DefaultScope;</TD></TR><TR><TD CLASS="l">40</TD><TD>import org.eclipse.core.runtime.preferences.IPreferencesService;</TD></TR><TR><TD CLASS="l">41</TD><TD>import org.eclipse.core.runtime.preferences.IScopeContext;</TD></TR><TR><TD CLASS="l">42</TD><TD>import org.eclipse.core.runtime.preferences.InstanceScope;</TD></TR><TR><TD CLASS="l">43</TD><TD>import org.eclipse.wst.sse.core.internal.Logger;</TD></TR><TR><TD CLASS="l">44</TD><TD>import org.eclipse.wst.sse.core.internal.provisional.tasks.IFileTaskScanner;</TD></TR><TR><TD CLASS="l">45</TD><TD>import org.eclipse.wst.sse.core.internal.provisional.tasks.TaskTag;</TD></TR><TR><TD CLASS="l">46</TD><TD>import org.eclipse.wst.sse.core.utils.StringUtils;</TD></TR><TR><TD CLASS="l">47</TD><TD> </TD></TR><TR><TD CLASS="l"><A NAME="0">48</A></TD><TD>/**</TD></TR><TR><TD CLASS="l">49</TD><TD> * Dispatcher for scanning based on deltas and requested projects</TD></TR><TR><TD CLASS="l">50</TD><TD> */</TD></TR><TR CLASS="z"><TD CLASS="l">51</TD><TD>class WorkspaceTaskScanner {</TD></TR><TR CLASS="z"><TD CLASS="l">52</TD><TD>        private static WorkspaceTaskScanner _instance = null;</TD></TR><TR><TD CLASS="l"><A NAME="4">53</A></TD><TD>        static final String SYNTHETIC_TASK = &#34;org.eclipse.wst.sse.task-synthetic&#34;;</TD></TR><TR><TD CLASS="l">54</TD><TD>        static final String MODIFICATION_STAMP = &#34;org.eclipse.wst.sse.modification-stamp&#34;;</TD></TR><TR><TD CLASS="l">55</TD><TD> </TD></TR><TR><TD CLASS="l">56</TD><TD>        static synchronized WorkspaceTaskScanner getInstance() {</TD></TR><TR CLASS="z"><TD CLASS="l">57</TD><TD>                if (_instance == null) {</TD></TR><TR CLASS="z"><TD CLASS="l">58</TD><TD>                        _instance = new WorkspaceTaskScanner();</TD></TR><TR><TD CLASS="l">59</TD><TD>                }</TD></TR><TR CLASS="z"><TD CLASS="l">60</TD><TD>                return _instance;</TD></TR><TR><TD CLASS="l">61</TD><TD>        }</TD></TR><TR><TD CLASS="l">62</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">63</TD><TD>        final String DEFAULT_MARKER_TYPE = IFileTaskScanner.TASK_MARKER_ID;</TD></TR><TR CLASS="z"><TD CLASS="l">64</TD><TD>        private List fActiveScanners = null;</TD></TR><TR CLASS="z"><TD CLASS="l">65</TD><TD>        private IContentType[] fCurrentIgnoreContentTypes = null;</TD></TR><TR CLASS="z"><TD CLASS="l">66</TD><TD>        private TaskTag[] fCurrentTaskTags = null;</TD></TR><TR><TD CLASS="l">67</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">68</TD><TD>        private FileTaskScannerRegistryReader registry = null;</TD></TR><TR><TD CLASS="l">69</TD><TD> </TD></TR><TR><TD CLASS="l">70</TD><TD>        private long time0;</TD></TR><TR><TD CLASS="l">71</TD><TD> </TD></TR><TR><TD CLASS="l"><A NAME="2">72</A></TD><TD>        /**</TD></TR><TR><TD CLASS="l">73</TD><TD>         * </TD></TR><TR><TD CLASS="l">74</TD><TD>         */</TD></TR><TR><TD CLASS="l">75</TD><TD>        private WorkspaceTaskScanner() {</TD></TR><TR CLASS="z"><TD CLASS="l">76</TD><TD>                super();</TD></TR><TR CLASS="z"><TD CLASS="l">77</TD><TD>                registry = FileTaskScannerRegistryReader.getInstance();</TD></TR><TR CLASS="z"><TD CLASS="l">78</TD><TD>                fActiveScanners = new ArrayList();</TD></TR><TR CLASS="z"><TD CLASS="l">79</TD><TD>                fCurrentTaskTags = new TaskTag[0];</TD></TR><TR CLASS="z"><TD CLASS="l"><A NAME="3">80</A></TD><TD>                fCurrentIgnoreContentTypes = new IContentType[0];</TD></TR><TR CLASS="z"><TD CLASS="l">81</TD><TD>        }</TD></TR><TR><TD CLASS="l">82</TD><TD> </TD></TR><TR><TD CLASS="l">83</TD><TD>        private IContentType[] detectContentTypes(IResource resource) {</TD></TR><TR CLASS="z"><TD CLASS="l">84</TD><TD>                IContentType[] types = null;</TD></TR><TR CLASS="z"><TD CLASS="l">85</TD><TD>                if (resource.getType() == IResource.FILE &amp;&amp; resource.isAccessible()) {</TD></TR><TR CLASS="z"><TD CLASS="l">86</TD><TD>                        types = Platform.getContentTypeManager().findContentTypesFor(resource.getName());</TD></TR><TR CLASS="z"><TD CLASS="l">87</TD><TD>                        if (types.length == 0) {</TD></TR><TR CLASS="z"><TD CLASS="l">88</TD><TD>                                IContentDescription d = null;</TD></TR><TR><TD CLASS="l">89</TD><TD>                                try {</TD></TR><TR><TD CLASS="l">90</TD><TD>                                        // optimized description lookup, might not succeed</TD></TR><TR CLASS="z"><TD CLASS="l">91</TD><TD>                                        d = ((IFile) resource).getContentDescription();</TD></TR><TR CLASS="z"><TD CLASS="l">92</TD><TD>                                        if (d != null) {</TD></TR><TR CLASS="z"><TD CLASS="l">93</TD><TD>                                                types = new IContentType[]{d.getContentType()};</TD></TR><TR><TD CLASS="l">94</TD><TD>                                        }</TD></TR><TR><TD CLASS="l">95</TD><TD>                                }</TD></TR><TR CLASS="z"><TD CLASS="l">96</TD><TD>                                catch (CoreException e) {</TD></TR><TR><TD CLASS="l">97</TD><TD>                                        /*</TD></TR><TR><TD CLASS="l">98</TD><TD>                                         * should not be possible given the accessible and file</TD></TR><TR><TD CLASS="l">99</TD><TD>                                         * type check above</TD></TR><TR><TD CLASS="l">100</TD><TD>                                         */</TD></TR><TR><TD CLASS="l">101</TD><TD>                                }</TD></TR><TR><TD CLASS="l">102</TD><TD>                        }</TD></TR><TR CLASS="z"><TD CLASS="l">103</TD><TD>                        if (types == null) {</TD></TR><TR CLASS="z"><TD CLASS="l">104</TD><TD>                                types = Platform.getContentTypeManager().findContentTypesFor(resource.getName());</TD></TR><TR><TD CLASS="l">105</TD><TD>                        }</TD></TR><TR CLASS="z"><TD CLASS="l">106</TD><TD>                        if (Logger.DEBUG_TASKSCONTENTTYPE) {</TD></TR><TR CLASS="z"><TD CLASS="l">107</TD><TD>                                if (types.length &gt; 0) {</TD></TR><TR CLASS="z"><TD CLASS="l">108</TD><TD>                                        if (types.length &gt; 1) {</TD></TR><TR CLASS="z"><TD CLASS="l">109</TD><TD>                                                System.out.println(resource.getFullPath() + &#34;: &#34; + &#34;multiple based on name (probably hierarchical)&#34;); //$NON-NLS-1$ //$NON-NLS-2$</TD></TR><TR><TD CLASS="l">110</TD><TD>                                        }</TD></TR><TR CLASS="z"><TD CLASS="l">111</TD><TD>                                        for (int i = 0; i &lt; types.length; i++) {</TD></TR><TR CLASS="z"><TD CLASS="l">112</TD><TD>                                                System.out.println(resource.getFullPath() + &#34; matched: &#34; + types[i].getId()); //$NON-NLS-1$</TD></TR><TR><TD CLASS="l">113</TD><TD>                                        }</TD></TR><TR><TD CLASS="l">114</TD><TD>                                }</TD></TR><TR><TD CLASS="l">115</TD><TD>                        }</TD></TR><TR><TD CLASS="l">116</TD><TD>                }</TD></TR><TR CLASS="z"><TD CLASS="l">117</TD><TD>                return types;</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>        /**</TD></TR><TR><TD CLASS="l"><A NAME="5">121</A></TD><TD>         * @param resource</TD></TR><TR><TD CLASS="l">122</TD><TD>         * @return</TD></TR><TR><TD CLASS="l">123</TD><TD>         */</TD></TR><TR><TD CLASS="l">124</TD><TD>        private IProject getProject(IResource resource) {</TD></TR><TR CLASS="z"><TD CLASS="l">125</TD><TD>                IProject project = null;</TD></TR><TR CLASS="z"><TD CLASS="l">126</TD><TD>                if (resource.getType() == IResource.PROJECT) {</TD></TR><TR CLASS="z"><TD CLASS="l">127</TD><TD>                        project = (IProject) resource;</TD></TR><TR><TD CLASS="l">128</TD><TD>                }</TD></TR><TR><TD CLASS="l">129</TD><TD>                else {</TD></TR><TR CLASS="z"><TD CLASS="l">130</TD><TD>                        project = resource.getProject();</TD></TR><TR><TD CLASS="l">131</TD><TD>                }</TD></TR><TR CLASS="z"><TD CLASS="l"><A NAME="6">132</A></TD><TD>                return project;</TD></TR><TR><TD CLASS="l">133</TD><TD>        }</TD></TR><TR><TD CLASS="l">134</TD><TD> </TD></TR><TR><TD CLASS="l">135</TD><TD>        private boolean init(IResource resource) {</TD></TR><TR CLASS="z"><TD CLASS="l">136</TD><TD>                IProject project = getProject(resource);</TD></TR><TR><TD CLASS="l">137</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">138</TD><TD>                IPreferencesService preferencesService = Platform.getPreferencesService();</TD></TR><TR CLASS="z"><TD CLASS="l">139</TD><TD>                IScopeContext[] lookupOrder = new IScopeContext[]{new ProjectScope(project), new InstanceScope(), new DefaultScope()};</TD></TR><TR><TD CLASS="l">140</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">141</TD><TD>                boolean proceed = preferencesService.getBoolean(TaskTagPreferenceKeys.TASK_TAG_NODE, TaskTagPreferenceKeys.TASK_TAG_ENABLE, false, lookupOrder);</TD></TR><TR><TD CLASS="l">142</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">143</TD><TD>                if (Logger.DEBUG_TASKSPREFS) {</TD></TR><TR CLASS="z"><TD CLASS="l">144</TD><TD>                        System.out.println(getClass().getName() + &#34; scan of &#34; + resource.getFullPath() + &#34;:&#34; + proceed); //$NON-NLS-1$ //$NON-NLS-2$</TD></TR><TR><TD CLASS="l">145</TD><TD>                }</TD></TR><TR><TD CLASS="l">146</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">147</TD><TD>                if (proceed) {</TD></TR><TR CLASS="z"><TD CLASS="l">148</TD><TD>                        String[] tags = StringUtils.unpack(preferencesService.getString(TaskTagPreferenceKeys.TASK_TAG_NODE, TaskTagPreferenceKeys.TASK_TAG_TAGS, null, lookupOrder));</TD></TR><TR CLASS="z"><TD CLASS="l">149</TD><TD>                        String[] priorities = StringUtils.unpack(preferencesService.getString(TaskTagPreferenceKeys.TASK_TAG_NODE, TaskTagPreferenceKeys.TASK_TAG_PRIORITIES, null, lookupOrder));</TD></TR><TR CLASS="z"><TD CLASS="l">150</TD><TD>                        String[] currentIgnoreContentTypeIDs = StringUtils.unpack(preferencesService.getString(TaskTagPreferenceKeys.TASK_TAG_NODE, TaskTagPreferenceKeys.TASK_TAG_CONTENTTYPES_IGNORED, null, lookupOrder));</TD></TR><TR CLASS="z"><TD CLASS="l">151</TD><TD>                        if (Logger.DEBUG_TASKSPREFS) {</TD></TR><TR CLASS="z"><TD CLASS="l">152</TD><TD>                                System.out.print(getClass().getName() + &#34; tags: &#34;); //$NON-NLS-1$</TD></TR><TR CLASS="z"><TD CLASS="l">153</TD><TD>                                for (int i = 0; i &lt; tags.length; i++) {</TD></TR><TR CLASS="z"><TD CLASS="l">154</TD><TD>                                        if (i &gt; 0) {</TD></TR><TR CLASS="z"><TD CLASS="l">155</TD><TD>                                                System.out.print(&#34;,&#34;); //$NON-NLS-1$</TD></TR><TR><TD CLASS="l">156</TD><TD>                                        }</TD></TR><TR CLASS="z"><TD CLASS="l">157</TD><TD>                                        System.out.print(tags[i]);</TD></TR><TR><TD CLASS="l">158</TD><TD>                                }</TD></TR><TR CLASS="z"><TD CLASS="l">159</TD><TD>                                System.out.println();</TD></TR><TR CLASS="z"><TD CLASS="l">160</TD><TD>                                System.out.print(getClass().getName() + &#34; priorities: &#34;); //$NON-NLS-1$</TD></TR><TR CLASS="z"><TD CLASS="l">161</TD><TD>                                for (int i = 0; i &lt; priorities.length; i++) {</TD></TR><TR CLASS="z"><TD CLASS="l">162</TD><TD>                                        if (i &gt; 0) {</TD></TR><TR CLASS="z"><TD CLASS="l">163</TD><TD>                                                System.out.print(&#34;,&#34;); //$NON-NLS-1$</TD></TR><TR><TD CLASS="l">164</TD><TD>                                        }</TD></TR><TR CLASS="z"><TD CLASS="l">165</TD><TD>                                        System.out.print(priorities[i]);</TD></TR><TR><TD CLASS="l">166</TD><TD>                                }</TD></TR><TR CLASS="z"><TD CLASS="l">167</TD><TD>                                System.out.println();</TD></TR><TR CLASS="z"><TD CLASS="l">168</TD><TD>                                System.out.print(getClass().getName() + &#34; ignored content types: &#34;); //$NON-NLS-1$</TD></TR><TR CLASS="z"><TD CLASS="l">169</TD><TD>                                for (int i = 0; i &lt; currentIgnoreContentTypeIDs.length; i++) {</TD></TR><TR CLASS="z"><TD CLASS="l">170</TD><TD>                                        if (i &gt; 0) {</TD></TR><TR CLASS="z"><TD CLASS="l">171</TD><TD>                                                System.out.print(&#34;,&#34;); //$NON-NLS-1$</TD></TR><TR><TD CLASS="l">172</TD><TD>                                        }</TD></TR><TR CLASS="z"><TD CLASS="l">173</TD><TD>                                        System.out.print(currentIgnoreContentTypeIDs[i]);</TD></TR><TR><TD CLASS="l">174</TD><TD>                                }</TD></TR><TR CLASS="z"><TD CLASS="l">175</TD><TD>                                System.out.println();</TD></TR><TR><TD CLASS="l">176</TD><TD>                        }</TD></TR><TR CLASS="z"><TD CLASS="l">177</TD><TD>                        fCurrentIgnoreContentTypes = new IContentType[currentIgnoreContentTypeIDs.length];</TD></TR><TR CLASS="z"><TD CLASS="l">178</TD><TD>                        IContentTypeManager contentTypeManager = Platform.getContentTypeManager();</TD></TR><TR CLASS="z"><TD CLASS="l">179</TD><TD>                        for (int i = 0; i &lt; currentIgnoreContentTypeIDs.length; i++) {</TD></TR><TR CLASS="z"><TD CLASS="l">180</TD><TD>                                fCurrentIgnoreContentTypes[i] = contentTypeManager.getContentType(currentIgnoreContentTypeIDs[i]);</TD></TR><TR><TD CLASS="l">181</TD><TD>                        }</TD></TR><TR CLASS="z"><TD CLASS="l">182</TD><TD>                        int max = Math.min(tags.length, priorities.length);</TD></TR><TR CLASS="z"><TD CLASS="l">183</TD><TD>                        fCurrentTaskTags = new TaskTag[max];</TD></TR><TR CLASS="z"><TD CLASS="l">184</TD><TD>                        for (int i = 0; i &lt; max; i++) {</TD></TR><TR CLASS="z"><TD CLASS="l">185</TD><TD>                                int priority = TaskTag.PRIORITY_NORMAL;</TD></TR><TR><TD CLASS="l">186</TD><TD>                                try {</TD></TR><TR CLASS="z"><TD CLASS="l">187</TD><TD>                                        priority = Integer.parseInt(priorities[i]);</TD></TR><TR><TD CLASS="l">188</TD><TD>                                }</TD></TR><TR CLASS="z"><TD CLASS="l">189</TD><TD>                                catch (NumberFormatException e) {</TD></TR><TR><TD CLASS="l">190</TD><TD>                                        // default to normal priority</TD></TR><TR><TD CLASS="l">191</TD><TD>                                }</TD></TR><TR CLASS="z"><TD CLASS="l">192</TD><TD>                                fCurrentTaskTags[i] = new TaskTag(tags[i], priority);</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"><A NAME="7">195</A></TD><TD>                return proceed;</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>        void internalScan(final IProject project, final IResource resource, final IProgressMonitor scanMonitor) {</TD></TR><TR CLASS="z"><TD CLASS="l">199</TD><TD>                if (scanMonitor.isCanceled())</TD></TR><TR CLASS="z"><TD CLASS="l">200</TD><TD>                        return;</TD></TR><TR><TD CLASS="l">201</TD><TD>                try {</TD></TR><TR CLASS="z"><TD CLASS="l">202</TD><TD>                        String name = resource.getName();</TD></TR><TR CLASS="z"><TD CLASS="l">203</TD><TD>                        if (resource.isAccessible() &amp;&amp; !resource.isDerived() &amp;&amp; !resource.isPhantom() &amp;&amp; !resource.isTeamPrivateMember() &amp;&amp; name.length() != 0 &amp;&amp; name.charAt(0) != '.') {</TD></TR><TR CLASS="z"><TD CLASS="l">204</TD><TD>                                if ((resource.getType() &amp; IResource.FOLDER) &gt; 0 || (resource.getType() &amp; IResource.PROJECT) &gt; 0) {</TD></TR><TR CLASS="z"><TD CLASS="l">205</TD><TD>                                        IResource[] children = ((IContainer) resource).members();</TD></TR><TR CLASS="z"><TD CLASS="l">206</TD><TD>                                        scanMonitor.beginTask(&#34;&#34;, children.length); //$NON-NLS-1$</TD></TR><TR CLASS="z"><TD CLASS="l">207</TD><TD>                                        for (int i = 0; i &lt; children.length; i++) {</TD></TR><TR CLASS="z"><TD CLASS="l">208</TD><TD>                                                internalScan(project, children[i], new SubProgressMonitor(scanMonitor, 1, SubProgressMonitor.PREPEND_MAIN_LABEL_TO_SUBTASK));</TD></TR><TR><TD CLASS="l">209</TD><TD>                                        }</TD></TR><TR CLASS="z"><TD CLASS="l">210</TD><TD>                                        scanMonitor.done();</TD></TR><TR><TD CLASS="l">211</TD><TD>                                }</TD></TR><TR CLASS="z"><TD CLASS="l">212</TD><TD>                                else if ((resource.getType() &amp; IResource.FILE) &gt; 0) {</TD></TR><TR CLASS="z"><TD CLASS="l">213</TD><TD>                                        scanFile(project, fCurrentTaskTags, (IFile) resource, scanMonitor);</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 CLASS="z"><TD CLASS="l">217</TD><TD>                catch (CoreException e) {</TD></TR><TR CLASS="z"><TD CLASS="l">218</TD><TD>                        Logger.logException(e);</TD></TR><TR><TD CLASS="l"><A NAME="8">219</A></TD><TD>                }</TD></TR><TR CLASS="z"><TD CLASS="l">220</TD><TD>        }</TD></TR><TR><TD CLASS="l">221</TD><TD> </TD></TR><TR><TD CLASS="l">222</TD><TD>        void internalScan(IResourceDelta delta, final IProgressMonitor monitor) {</TD></TR><TR CLASS="z"><TD CLASS="l">223</TD><TD>                if (monitor.isCanceled())</TD></TR><TR CLASS="z"><TD CLASS="l">224</TD><TD>                        return;</TD></TR><TR><TD CLASS="l">225</TD><TD>                try {</TD></TR><TR CLASS="z"><TD CLASS="l">226</TD><TD>                        String name = delta.getFullPath().lastSegment();</TD></TR><TR CLASS="z"><TD CLASS="l">227</TD><TD>                        IResource resource = delta.getResource();</TD></TR><TR CLASS="z"><TD CLASS="l">228</TD><TD>                        if (!resource.isDerived() &amp;&amp; !resource.isPhantom() &amp;&amp; !resource.isTeamPrivateMember() &amp;&amp; name.length() != 0 &amp;&amp; name.charAt(0) != '.') {</TD></TR><TR CLASS="z"><TD CLASS="l">229</TD><TD>                                if ((resource.getType() &amp; IResource.FOLDER) &gt; 0 || (resource.getType() &amp; IResource.PROJECT) &gt; 0) {</TD></TR><TR CLASS="z"><TD CLASS="l">230</TD><TD>                                        IResourceDelta[] children = delta.getAffectedChildren();</TD></TR><TR CLASS="z"><TD CLASS="l">231</TD><TD>                                        monitor.beginTask(&#34;&#34;, children.length);</TD></TR><TR CLASS="z"><TD CLASS="l">232</TD><TD>                                        if (name.length() != 0 &amp;&amp; name.charAt(0) != '.' &amp;&amp; children.length &gt; 0) {</TD></TR><TR CLASS="z"><TD CLASS="l">233</TD><TD>                                                for (int i = children.length - 1; i &gt;= 0; i--) {</TD></TR><TR CLASS="z"><TD CLASS="l">234</TD><TD>                                                        internalScan(children[i], new SubProgressMonitor(monitor, 1, SubProgressMonitor.PREPEND_MAIN_LABEL_TO_SUBTASK));</TD></TR><TR><TD CLASS="l">235</TD><TD>                                                }</TD></TR><TR><TD CLASS="l">236</TD><TD>                                        }</TD></TR><TR CLASS="z"><TD CLASS="l">237</TD><TD>                                        monitor.done();</TD></TR><TR><TD CLASS="l">238</TD><TD>                                }</TD></TR><TR CLASS="z"><TD CLASS="l">239</TD><TD>                                else if ((resource.getType() &amp; IResource.FILE) &gt; 0) {</TD></TR><TR CLASS="z"><TD CLASS="l">240</TD><TD>                                        if ((delta.getKind() &amp; IResourceDelta.ADDED) &gt; 0 || ((delta.getKind() &amp; IResourceDelta.CHANGED) &gt; 0 &amp;&amp; (delta.getFlags() &amp; IResourceDelta.CONTENT) &gt; 0)) {</TD></TR><TR CLASS="z"><TD CLASS="l">241</TD><TD>                                                IFile file = (IFile) resource;</TD></TR><TR CLASS="z"><TD CLASS="l">242</TD><TD>                                                scanFile(file.getProject(), fCurrentTaskTags, file, monitor);</TD></TR><TR><TD CLASS="l">243</TD><TD>                                        }</TD></TR><TR><TD CLASS="l">244</TD><TD>                                }</TD></TR><TR><TD CLASS="l">245</TD><TD>                        }</TD></TR><TR><TD CLASS="l">246</TD><TD>                }</TD></TR><TR CLASS="z"><TD CLASS="l">247</TD><TD>                catch (Exception e) {</TD></TR><TR CLASS="z"><TD CLASS="l">248</TD><TD>                        Logger.logException(e);</TD></TR><TR><TD CLASS="l"><A NAME="9">249</A></TD><TD>                }</TD></TR><TR CLASS="z"><TD CLASS="l">250</TD><TD>        }</TD></TR><TR><TD CLASS="l">251</TD><TD> </TD></TR><TR><TD CLASS="l"><A NAME="e">252</A></TD><TD>        private void replaceTaskMarkers(final IFile file, final String[] markerTypes, final Map markerAttributeMaps[], IProgressMonitor monitor) {</TD></TR><TR CLASS="z"><TD CLASS="l">253</TD><TD>                final IFile finalFile = file;</TD></TR><TR CLASS="z"><TD CLASS="l"><A NAME="10">254</A></TD><TD>                if (file.isAccessible()) {</TD></TR><TR><TD CLASS="l">255</TD><TD>                        try {</TD></TR><TR CLASS="z"><TD CLASS="l">256</TD><TD>                                IWorkspaceRunnable r = new IWorkspaceRunnable() {</TD></TR><TR><TD CLASS="l">257</TD><TD>                                        public void run(IProgressMonitor progressMonitor) throws CoreException {</TD></TR><TR CLASS="z"><TD CLASS="l">258</TD><TD>                                                progressMonitor.beginTask(&#34;&#34;, 2);//$NON-NLS-1$</TD></TR><TR><TD CLASS="l">259</TD><TD>                                                try {</TD></TR><TR><TD CLASS="l">260</TD><TD>                                                        /*</TD></TR><TR><TD CLASS="l">261</TD><TD>                                                         * Delete old Task markers (don't delete regular</TD></TR><TR><TD CLASS="l">262</TD><TD>                                                         * Tasks since that includes user-defined ones)</TD></TR><TR><TD CLASS="l">263</TD><TD>                                                         */</TD></TR><TR CLASS="z"><TD CLASS="l">264</TD><TD>                                                        for (int i = 0; i &lt; markerTypes.length; i++) {</TD></TR><TR CLASS="z"><TD CLASS="l">265</TD><TD>                                                                if (IMarker.TASK.equals(markerTypes[i])) {</TD></TR><TR><TD CLASS="l">266</TD><TD>                                                                        // only remove if synthetic</TD></TR><TR CLASS="z"><TD CLASS="l">267</TD><TD>                                                                        IMarker[] foundMarkers = file.findMarkers(markerTypes[i], true, IResource.DEPTH_ZERO);</TD></TR><TR CLASS="z"><TD CLASS="l">268</TD><TD>                                                                        for (int j = 0; j &lt; foundMarkers.length; j++) {</TD></TR><TR CLASS="z"><TD CLASS="l">269</TD><TD>                                                                                if (foundMarkers[j].getAttribute(SYNTHETIC_TASK) != null) {</TD></TR><TR CLASS="z"><TD CLASS="l">270</TD><TD>                                                                                        foundMarkers[j].delete();</TD></TR><TR><TD CLASS="l">271</TD><TD>                                                                                }</TD></TR><TR><TD CLASS="l">272</TD><TD>                                                                        }</TD></TR><TR><TD CLASS="l">273</TD><TD>                                                                }</TD></TR><TR><TD CLASS="l">274</TD><TD>                                                                else {</TD></TR><TR CLASS="z"><TD CLASS="l">275</TD><TD>                                                                        file.deleteMarkers(markerTypes[i], true, IResource.DEPTH_ZERO);</TD></TR><TR><TD CLASS="l">276</TD><TD>                                                                }</TD></TR><TR><TD CLASS="l">277</TD><TD>                                                        }</TD></TR><TR><TD CLASS="l">278</TD><TD>                                                }</TD></TR><TR CLASS="z"><TD CLASS="l">279</TD><TD>                                                catch (CoreException e) {</TD></TR><TR CLASS="z"><TD CLASS="l">280</TD><TD>                                                        Logger.logException(&#34;exception deleting old tasks&#34;, e); //$NON-NLS-1$ </TD></TR><TR><TD CLASS="l">281</TD><TD>                                                }</TD></TR><TR CLASS="z"><TD CLASS="l">282</TD><TD>                                                finally {</TD></TR><TR CLASS="z"><TD CLASS="l">283</TD><TD>                                                        progressMonitor.worked(1);</TD></TR><TR CLASS="z"><TD CLASS="l">284</TD><TD>                                                }</TD></TR><TR CLASS="z"><TD CLASS="l">285</TD><TD>                                                if (markerAttributeMaps != null &amp;&amp; markerAttributeMaps.length &gt; 0) {</TD></TR><TR CLASS="z"><TD CLASS="l">286</TD><TD>                                                        if (Logger.DEBUG_TASKS) {</TD></TR><TR CLASS="z"><TD CLASS="l">287</TD><TD>                                                                System.out.println(&#34;&#34; + markerAttributeMaps.length + &#34; tasks for &#34; + file.getFullPath()); //$NON-NLS-1$ //$NON-NLS-2$</TD></TR><TR><TD CLASS="l">288</TD><TD>                                                        }</TD></TR><TR CLASS="z"><TD CLASS="l">289</TD><TD>                                                        for (int i = 0; i &lt; markerAttributeMaps.length; i++) {</TD></TR><TR CLASS="z"><TD CLASS="l">290</TD><TD>                                                                String specifiedMarkerType = (String) markerAttributeMaps[i].get(IMarker.TASK);</TD></TR><TR CLASS="z"><TD CLASS="l">291</TD><TD>                                                                IMarker marker = finalFile.createMarker(specifiedMarkerType);</TD></TR><TR CLASS="z"><TD CLASS="l">292</TD><TD>                                                                marker.setAttributes(markerAttributeMaps[i]);</TD></TR><TR CLASS="z"><TD CLASS="l">293</TD><TD>                                                                marker.setAttribute(IMarker.USER_EDITABLE, Boolean.FALSE);</TD></TR><TR CLASS="z"><TD CLASS="l">294</TD><TD>                                                                marker.setAttribute(MODIFICATION_STAMP, Long.toString(file.getModificationStamp()));</TD></TR><TR CLASS="z"><TD CLASS="l">295</TD><TD>                                                                if (IMarker.TASK.equals(specifiedMarkerType)) {</TD></TR><TR><TD CLASS="l">296</TD><TD>                                                                        // set to synthetic and make user editable</TD></TR><TR CLASS="z"><TD CLASS="l">297</TD><TD>                                                                        marker.setAttribute(SYNTHETIC_TASK, true);</TD></TR><TR><TD CLASS="l">298</TD><TD>                                                                }</TD></TR><TR><TD CLASS="l">299</TD><TD>                                                        }</TD></TR><TR><TD CLASS="l">300</TD><TD>                                                }</TD></TR><TR CLASS="z"><TD CLASS="l">301</TD><TD>                                                progressMonitor.worked(1);</TD></TR><TR CLASS="z"><TD CLASS="l">302</TD><TD>                                                progressMonitor.done();</TD></TR><TR CLASS="z"><TD CLASS="l">303</TD><TD>                                        }</TD></TR><TR><TD CLASS="l">304</TD><TD>                                };</TD></TR><TR CLASS="z"><TD CLASS="l">305</TD><TD>                                if (file.isAccessible()) {</TD></TR><TR CLASS="z"><TD CLASS="l">306</TD><TD>                                        finalFile.getWorkspace().run(r, ResourcesPlugin.getWorkspace().getRuleFactory().modifyRule(file), IWorkspace.AVOID_UPDATE, monitor);</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>                        catch (CoreException e1) {</TD></TR><TR CLASS="z"><TD CLASS="l">310</TD><TD>                                Logger.logException(e1);</TD></TR><TR><TD CLASS="l">311</TD><TD>                        }</TD></TR><TR CLASS="z"><TD CLASS="l">312</TD><TD>                        catch(OperationCanceledException e) {</TD></TR><TR><TD CLASS="l">313</TD><TD>                                // not an error condition</TD></TR><TR><TD CLASS="l">314</TD><TD>                        }</TD></TR><TR><TD CLASS="l"><A NAME="a">315</A></TD><TD>                }</TD></TR><TR CLASS="z"><TD CLASS="l">316</TD><TD>        }</TD></TR><TR><TD CLASS="l">317</TD><TD> </TD></TR><TR><TD CLASS="l">318</TD><TD>        void scan(final IProject project, final IProgressMonitor scanMonitor) {</TD></TR><TR CLASS="z"><TD CLASS="l">319</TD><TD>                if (scanMonitor.isCanceled())</TD></TR><TR CLASS="z"><TD CLASS="l">320</TD><TD>                        return;</TD></TR><TR CLASS="z"><TD CLASS="l">321</TD><TD>                if (Logger.DEBUG_TASKS) {</TD></TR><TR CLASS="z"><TD CLASS="l">322</TD><TD>                        System.out.println(getClass().getName() + &#34; scanning project &#34; + project.getName()); //$NON-NLS-1$</TD></TR><TR><TD CLASS="l">323</TD><TD>                }</TD></TR><TR CLASS="z"><TD CLASS="l">324</TD><TD>                if (!project.isAccessible()) {</TD></TR><TR CLASS="z"><TD CLASS="l">325</TD><TD>                        if (Logger.DEBUG_TASKS) {</TD></TR><TR CLASS="z"><TD CLASS="l">326</TD><TD>                                System.out.println(getClass().getName() + &#34; skipping inaccessible project &#34; + project.getName()); //$NON-NLS-1$</TD></TR><TR><TD CLASS="l">327</TD><TD>                        }</TD></TR><TR CLASS="z"><TD CLASS="l">328</TD><TD>                        return;</TD></TR><TR><TD CLASS="l">329</TD><TD>                }</TD></TR><TR><TD CLASS="l">330</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">331</TD><TD>                if (Logger.DEBUG_TASKSOVERALLPERF) {</TD></TR><TR CLASS="z"><TD CLASS="l">332</TD><TD>                        time0 = System.currentTimeMillis();</TD></TR><TR><TD CLASS="l">333</TD><TD>                }</TD></TR><TR CLASS="z"><TD CLASS="l">334</TD><TD>                if (init(project)) {</TD></TR><TR CLASS="z"><TD CLASS="l">335</TD><TD>                        internalScan(project, project, scanMonitor);</TD></TR><TR CLASS="z"><TD CLASS="l">336</TD><TD>                        shutdownDelegates(project);</TD></TR><TR><TD CLASS="l">337</TD><TD>                }</TD></TR><TR CLASS="z"><TD CLASS="l">338</TD><TD>                if (Logger.DEBUG_TASKSOVERALLPERF) {</TD></TR><TR CLASS="z"><TD CLASS="l">339</TD><TD>                        System.out.println(&#34;&#34; + (System.currentTimeMillis() - time0) + &#34;ms for &#34; + project.getFullPath()); //$NON-NLS-1$ //$NON-NLS-2$</TD></TR><TR><TD CLASS="l">340</TD><TD>                }</TD></TR><TR CLASS="z"><TD CLASS="l"><A NAME="b">341</A></TD><TD>        }</TD></TR><TR><TD CLASS="l">342</TD><TD> </TD></TR><TR><TD CLASS="l">343</TD><TD> </TD></TR><TR><TD CLASS="l">344</TD><TD>        void scan(IResourceDelta delta, final IProgressMonitor monitor) {</TD></TR><TR CLASS="z"><TD CLASS="l">345</TD><TD>                if (monitor.isCanceled())</TD></TR><TR CLASS="z"><TD CLASS="l">346</TD><TD>                        return;</TD></TR><TR CLASS="z"><TD CLASS="l">347</TD><TD>                if (Logger.DEBUG_TASKSOVERALLPERF) {</TD></TR><TR CLASS="z"><TD CLASS="l">348</TD><TD>                        time0 = System.currentTimeMillis();</TD></TR><TR><TD CLASS="l">349</TD><TD>                }</TD></TR><TR CLASS="z"><TD CLASS="l">350</TD><TD>                if (init(delta.getResource())) {</TD></TR><TR CLASS="z"><TD CLASS="l">351</TD><TD>                        internalScan(delta, monitor);</TD></TR><TR CLASS="z"><TD CLASS="l">352</TD><TD>                        shutdownDelegates(delta.getResource().getProject());</TD></TR><TR><TD CLASS="l">353</TD><TD>                }</TD></TR><TR CLASS="z"><TD CLASS="l">354</TD><TD>                if (Logger.DEBUG_TASKSOVERALLPERF) {</TD></TR><TR CLASS="z"><TD CLASS="l">355</TD><TD>                        System.out.println(&#34;&#34; + (System.currentTimeMillis() - time0) + &#34;ms for &#34; + delta.getFullPath()); //$NON-NLS-1$ //$NON-NLS-2$</TD></TR><TR><TD CLASS="l"><A NAME="c">356</A></TD><TD>                }</TD></TR><TR CLASS="z"><TD CLASS="l">357</TD><TD>        }</TD></TR><TR><TD CLASS="l">358</TD><TD> </TD></TR><TR><TD CLASS="l">359</TD><TD>        void scanFile(IProject project, TaskTag[] taskTags, IFile file, IProgressMonitor monitor) {</TD></TR><TR CLASS="z"><TD CLASS="l">360</TD><TD>                if (monitor.isCanceled())</TD></TR><TR CLASS="z"><TD CLASS="l">361</TD><TD>                        return;</TD></TR><TR><TD CLASS="l">362</TD><TD> </TD></TR><TR><TD CLASS="l">363</TD><TD>                // 3 &#34;stages&#34;</TD></TR><TR CLASS="z"><TD CLASS="l">364</TD><TD>                monitor.beginTask(&#34;&#34;, 8);//$NON-NLS-1$</TD></TR><TR CLASS="z"><TD CLASS="l">365</TD><TD>                monitor.subTask(file.getFullPath().toString().substring(1));</TD></TR><TR><TD CLASS="l">366</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">367</TD><TD>                List markerAttributes = null;</TD></TR><TR CLASS="z"><TD CLASS="l">368</TD><TD>                IContentType[] types = detectContentTypes(file);</TD></TR><TR CLASS="z"><TD CLASS="l">369</TD><TD>                Set markerTypes = new HashSet(3);</TD></TR><TR><TD CLASS="l">370</TD><TD>                // Always included for safety and migration</TD></TR><TR CLASS="z"><TD CLASS="l">371</TD><TD>                markerTypes.add(DEFAULT_MARKER_TYPE);</TD></TR><TR CLASS="z"><TD CLASS="l">372</TD><TD>                monitor.worked(1);</TD></TR><TR><TD CLASS="l">373</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">374</TD><TD>                IFileTaskScanner[] fileScanners = null;</TD></TR><TR CLASS="z"><TD CLASS="l">375</TD><TD>                if (types != null) {</TD></TR><TR CLASS="z"><TD CLASS="l">376</TD><TD>                        if (fCurrentIgnoreContentTypes.length == 0) {</TD></TR><TR CLASS="z"><TD CLASS="l">377</TD><TD>                                fileScanners = registry.getFileTaskScanners(types);</TD></TR><TR><TD CLASS="l">378</TD><TD>                        }</TD></TR><TR><TD CLASS="l">379</TD><TD>                        else {</TD></TR><TR CLASS="z"><TD CLASS="l">380</TD><TD>                                List validTypes = new ArrayList();</TD></TR><TR><TD CLASS="l">381</TD><TD>                                // obtain a filtered list of delegates</TD></TR><TR CLASS="z"><TD CLASS="l">382</TD><TD>                                for (int i = 0; i &lt; types.length; i++) {</TD></TR><TR CLASS="z"><TD CLASS="l">383</TD><TD>                                        boolean ignoreContentType = false;</TD></TR><TR CLASS="z"><TD CLASS="l">384</TD><TD>                                        for (int j = 0; j &lt; fCurrentIgnoreContentTypes.length; j++) {</TD></TR><TR CLASS="z"><TD CLASS="l">385</TD><TD>                                                ignoreContentType = ignoreContentType || types[i].isKindOf(fCurrentIgnoreContentTypes[j]);</TD></TR><TR><TD CLASS="l">386</TD><TD>                                        }</TD></TR><TR CLASS="z"><TD CLASS="l">387</TD><TD>                                        if (!ignoreContentType) {</TD></TR><TR CLASS="z"><TD CLASS="l">388</TD><TD>                                                validTypes.add(types[i]);</TD></TR><TR><TD CLASS="l">389</TD><TD>                                        }</TD></TR><TR><TD CLASS="l">390</TD><TD>                                }</TD></TR><TR CLASS="z"><TD CLASS="l">391</TD><TD>                                fileScanners = registry.getFileTaskScanners((IContentType[]) validTypes.toArray(new IContentType[validTypes.size()]));</TD></TR><TR><TD CLASS="l">392</TD><TD>                        }</TD></TR><TR CLASS="z"><TD CLASS="l">393</TD><TD>                        monitor.worked(1);</TD></TR><TR><TD CLASS="l">394</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">395</TD><TD>                        if (fileScanners.length &gt; 0) {</TD></TR><TR CLASS="z"><TD CLASS="l">396</TD><TD>                                IProgressMonitor scannerMonitor = new SubProgressMonitor(monitor, 3, SubProgressMonitor.PREPEND_MAIN_LABEL_TO_SUBTASK);</TD></TR><TR CLASS="z"><TD CLASS="l">397</TD><TD>                                scannerMonitor.beginTask(&#34;&#34;, fileScanners.length); //$NON-NLS-1$</TD></TR><TR CLASS="z"><TD CLASS="l">398</TD><TD>                                for (int j = 0; fileScanners != null &amp;&amp; j &lt; fileScanners.length; j++) {</TD></TR><TR CLASS="z"><TD CLASS="l">399</TD><TD>                                        if (monitor.isCanceled())</TD></TR><TR CLASS="z"><TD CLASS="l">400</TD><TD>                                                continue;</TD></TR><TR><TD CLASS="l">401</TD><TD>                                        try {</TD></TR><TR CLASS="z"><TD CLASS="l">402</TD><TD>                                                if (!fActiveScanners.contains(fileScanners[j]) &amp;&amp; !monitor.isCanceled()) {</TD></TR><TR CLASS="z"><TD CLASS="l">403</TD><TD>                                                        fileScanners[j].startup(file.getProject());</TD></TR><TR CLASS="z"><TD CLASS="l">404</TD><TD>                                                        fActiveScanners.add(fileScanners[j]);</TD></TR><TR><TD CLASS="l">405</TD><TD>                                                }</TD></TR><TR CLASS="z"><TD CLASS="l">406</TD><TD>                                                markerTypes.add(fileScanners[j].getMarkerType());</TD></TR><TR CLASS="z"><TD CLASS="l">407</TD><TD>                                                Map[] taskMarkerAttributes = fileScanners[j].scan(file, taskTags, new SubProgressMonitor(scannerMonitor, 1, SubProgressMonitor.PREPEND_MAIN_LABEL_TO_SUBTASK));</TD></TR><TR><TD CLASS="l">408</TD><TD>                                                /*</TD></TR><TR><TD CLASS="l">409</TD><TD>                                                 * TODO: pool the marker results so there's only one</TD></TR><TR><TD CLASS="l">410</TD><TD>                                                 * operation creating them</TD></TR><TR><TD CLASS="l">411</TD><TD>                                                 */</TD></TR><TR CLASS="z"><TD CLASS="l">412</TD><TD>                                                for (int i = 0; i &lt; taskMarkerAttributes.length; i++) {</TD></TR><TR CLASS="z"><TD CLASS="l">413</TD><TD>                                                        if (markerAttributes == null) {</TD></TR><TR CLASS="z"><TD CLASS="l">414</TD><TD>                                                                markerAttributes = new ArrayList();</TD></TR><TR><TD CLASS="l">415</TD><TD>                                                        }</TD></TR><TR CLASS="z"><TD CLASS="l">416</TD><TD>                                                        if (!taskMarkerAttributes[i].containsKey(IMarker.TASK)) {</TD></TR><TR CLASS="z"><TD CLASS="l">417</TD><TD>                                                                taskMarkerAttributes[i].put(IMarker.TASK, fileScanners[j].getMarkerType());</TD></TR><TR><TD CLASS="l">418</TD><TD>                                                        }</TD></TR><TR CLASS="z"><TD CLASS="l">419</TD><TD>                                                        taskMarkerAttributes[i].put(IMarker.SOURCE_ID, fileScanners[j].getClass().getName());</TD></TR><TR CLASS="z"><TD CLASS="l">420</TD><TD>                                                        markerAttributes.add(taskMarkerAttributes[i]);</TD></TR><TR><TD CLASS="l">421</TD><TD>                                                }</TD></TR><TR><TD CLASS="l">422</TD><TD>                                        }</TD></TR><TR CLASS="z"><TD CLASS="l">423</TD><TD>                                        catch (Exception e) {</TD></TR><TR CLASS="z"><TD CLASS="l">424</TD><TD>                                                Logger.logException(file.getFullPath().toString(), e);</TD></TR><TR><TD CLASS="l">425</TD><TD>                                        }</TD></TR><TR><TD CLASS="l">426</TD><TD>                                }</TD></TR><TR CLASS="z"><TD CLASS="l">427</TD><TD>                                scannerMonitor.done();</TD></TR><TR><TD CLASS="l">428</TD><TD>                        }</TD></TR><TR><TD CLASS="l">429</TD><TD>                }</TD></TR><TR><TD CLASS="l">430</TD><TD>                else {</TD></TR><TR CLASS="z"><TD CLASS="l">431</TD><TD>                        monitor.worked(4);</TD></TR><TR><TD CLASS="l">432</TD><TD>                }</TD></TR><TR><TD CLASS="l">433</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">434</TD><TD>                if (monitor.isCanceled())</TD></TR><TR CLASS="z"><TD CLASS="l">435</TD><TD>                        return;</TD></TR><TR><TD CLASS="l">436</TD><TD>                // only update markers if we ran a scanner on this file</TD></TR><TR CLASS="z"><TD CLASS="l">437</TD><TD>                if (fileScanners != null &amp;&amp; fileScanners.length &gt; 0) {</TD></TR><TR CLASS="z"><TD CLASS="l">438</TD><TD>                        IProgressMonitor markerUpdateMonitor = new SubProgressMonitor(monitor, 3, SubProgressMonitor.PREPEND_MAIN_LABEL_TO_SUBTASK);</TD></TR><TR CLASS="z"><TD CLASS="l">439</TD><TD>                        if (markerAttributes != null) {</TD></TR><TR CLASS="z"><TD CLASS="l">440</TD><TD>                                replaceTaskMarkers(file, (String[]) markerTypes.toArray(new String[markerTypes.size()]), (Map[]) markerAttributes.toArray(new Map[markerAttributes.size()]), markerUpdateMonitor);</TD></TR><TR><TD CLASS="l">441</TD><TD>                        }</TD></TR><TR><TD CLASS="l">442</TD><TD>                }</TD></TR><TR><TD CLASS="l">443</TD><TD>                else {</TD></TR><TR CLASS="z"><TD CLASS="l">444</TD><TD>                        monitor.worked(3);</TD></TR><TR><TD CLASS="l">445</TD><TD>                }</TD></TR><TR CLASS="z"><TD CLASS="l"><A NAME="d">446</A></TD><TD>                monitor.done();</TD></TR><TR CLASS="z"><TD CLASS="l">447</TD><TD>        }</TD></TR><TR><TD CLASS="l">448</TD><TD> </TD></TR><TR><TD CLASS="l">449</TD><TD>        private void shutdownDelegates(IProject project) {</TD></TR><TR CLASS="z"><TD CLASS="l">450</TD><TD>                for (int j = 0; j &lt; fActiveScanners.size(); j++) {</TD></TR><TR><TD CLASS="l">451</TD><TD>                        try {</TD></TR><TR CLASS="z"><TD CLASS="l">452</TD><TD>                                ((IFileTaskScanner) fActiveScanners.get(j)).shutdown(project);</TD></TR><TR><TD CLASS="l">453</TD><TD>                        }</TD></TR><TR CLASS="z"><TD CLASS="l">454</TD><TD>                        catch (Exception e) {</TD></TR><TR CLASS="z"><TD CLASS="l">455</TD><TD>                                Logger.logException(project.getFullPath().toString(), e);</TD></TR><TR><TD CLASS="l">456</TD><TD>                        }</TD></TR><TR><TD CLASS="l">457</TD><TD>                }</TD></TR><TR CLASS="z"><TD CLASS="l">458</TD><TD>                fActiveScanners = new ArrayList(1);</TD></TR><TR CLASS="z"><TD CLASS="l">459</TD><TD>        }</TD></TR><TR><TD CLASS="l">460</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>