<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"><static initializer></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 = "org.eclipse.wst.sse.task-synthetic";</TD></TR><TR><TD CLASS="l">54</TD><TD> static final String MODIFICATION_STAMP = "org.eclipse.wst.sse.modification-stamp";</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 && 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 > 0) {</TD></TR><TR CLASS="z"><TD CLASS="l">108</TD><TD> if (types.length > 1) {</TD></TR><TR CLASS="z"><TD CLASS="l">109</TD><TD> System.out.println(resource.getFullPath() + ": " + "multiple based on name (probably hierarchical)"); //$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 < types.length; i++) {</TD></TR><TR CLASS="z"><TD CLASS="l">112</TD><TD> System.out.println(resource.getFullPath() + " matched: " + 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() + " scan of " + resource.getFullPath() + ":" + 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() + " tags: "); //$NON-NLS-1$</TD></TR><TR CLASS="z"><TD CLASS="l">153</TD><TD> for (int i = 0; i < tags.length; i++) {</TD></TR><TR CLASS="z"><TD CLASS="l">154</TD><TD> if (i > 0) {</TD></TR><TR CLASS="z"><TD CLASS="l">155</TD><TD> System.out.print(","); //$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() + " priorities: "); //$NON-NLS-1$</TD></TR><TR CLASS="z"><TD CLASS="l">161</TD><TD> for (int i = 0; i < priorities.length; i++) {</TD></TR><TR CLASS="z"><TD CLASS="l">162</TD><TD> if (i > 0) {</TD></TR><TR CLASS="z"><TD CLASS="l">163</TD><TD> System.out.print(","); //$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() + " ignored content types: "); //$NON-NLS-1$</TD></TR><TR CLASS="z"><TD CLASS="l">169</TD><TD> for (int i = 0; i < currentIgnoreContentTypeIDs.length; i++) {</TD></TR><TR CLASS="z"><TD CLASS="l">170</TD><TD> if (i > 0) {</TD></TR><TR CLASS="z"><TD CLASS="l">171</TD><TD> System.out.print(","); //$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 < 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 < 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() && !resource.isDerived() && !resource.isPhantom() && !resource.isTeamPrivateMember() && name.length() != 0 && name.charAt(0) != '.') {</TD></TR><TR CLASS="z"><TD CLASS="l">204</TD><TD> if ((resource.getType() & IResource.FOLDER) > 0 || (resource.getType() & IResource.PROJECT) > 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("", children.length); //$NON-NLS-1$</TD></TR><TR CLASS="z"><TD CLASS="l">207</TD><TD> for (int i = 0; i < 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() & IResource.FILE) > 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() && !resource.isPhantom() && !resource.isTeamPrivateMember() && name.length() != 0 && name.charAt(0) != '.') {</TD></TR><TR CLASS="z"><TD CLASS="l">229</TD><TD> if ((resource.getType() & IResource.FOLDER) > 0 || (resource.getType() & IResource.PROJECT) > 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("", children.length);</TD></TR><TR CLASS="z"><TD CLASS="l">232</TD><TD> if (name.length() != 0 && name.charAt(0) != '.' && children.length > 0) {</TD></TR><TR CLASS="z"><TD CLASS="l">233</TD><TD> for (int i = children.length - 1; i >= 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() & IResource.FILE) > 0) {</TD></TR><TR CLASS="z"><TD CLASS="l">240</TD><TD> if ((delta.getKind() & IResourceDelta.ADDED) > 0 || ((delta.getKind() & IResourceDelta.CHANGED) > 0 && (delta.getFlags() & IResourceDelta.CONTENT) > 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("", 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 < 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 < 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("exception deleting old tasks", 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 && markerAttributeMaps.length > 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("" + markerAttributeMaps.length + " tasks for " + 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 < 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() + " scanning project " + 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() + " skipping inaccessible project " + 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("" + (System.currentTimeMillis() - time0) + "ms for " + 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("" + (System.currentTimeMillis() - time0) + "ms for " + 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 "stages"</TD></TR><TR CLASS="z"><TD CLASS="l">364</TD><TD> monitor.beginTask("", 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 < 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 < 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 > 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("", fileScanners.length); //$NON-NLS-1$</TD></TR><TR CLASS="z"><TD CLASS="l">398</TD><TD> for (int j = 0; fileScanners != null && j < 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]) && !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 < 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 && fileScanners.length > 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 < 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> |