blob: 375a577e2d744282cea5f91ed88402d79a7863c5 [file] [log] [blame]
<HTML><HEAD><META CONTENT="text/html; charset=UTF-8" HTTP-EQUIV="Content-Type"/><TITLE>EMMA Coverage Report</TITLE><STYLE TYPE="text/css"> TABLE,TD,TH {border-style:solid; border-color:black;} TD,TH {background:white;margin:0;line-height:100%;padding-left:0.5em;padding-right:0.5em;} TD {border-width:0 1px 0 0;} TH {border-width:1px 1px 1px 0;} TR TD.h {color:red;} TABLE {border-spacing:0; border-collapse:collapse;border-width:0 0 1px 1px;} P,H1,H2,H3,TH {font-family:verdana,arial,sans-serif;font-size:10pt;} TD {font-family:courier,monospace;font-size:10pt;} TABLE.hdft {border-spacing:0;border-collapse:collapse;border-style:none;} TABLE.hdft TH,TABLE.hdft TD {border-style:none;line-height:normal;} TABLE.hdft TH.tl,TABLE.hdft TD.tl {background:#6699CC;color:white;} TABLE.hdft TD.nv {background:#6633DD;color:white;} .nv A:link {color:white;} .nv A:visited {color:white;} .nv A:active {color:yellow;} TABLE.hdft A:link {color:white;} TABLE.hdft A:visited {color:white;} TABLE.hdft A:active {color:yellow;} .in {color:#356085;} TABLE.s TD {padding-left:0.25em;padding-right:0.25em;} TABLE.s TD.l {padding-left:0.25em;padding-right:0.25em;text-align:right;background:#F0F0F0;} TABLE.s TR.z TD {background:#FF9999;} TABLE.s TR.p TD {background:#FFFF88;} TABLE.s TR.c TD {background:#CCFFCC;} A:link {color:#0000EE;text-decoration:none;} A:visited {color:#0000EE;text-decoration:none;} A:hover {color:#0000EE;text-decoration:underline;} TABLE.cn {border-width:0 0 1px 0;} TABLE.s {border-width:1px 0 1px 1px;} TD.h {color:red;border-width:0 1px 0 0;} TD.f {border-width:0 1px 0 1px;} TD.hf {color:red;border-width:0 1px 0 1px;} TH.f {border-width:1px 1px 1px 1px;} TR.cis TD {background:#F0F0F0;} TR.cis TD {border-width:1px 1px 1px 0;} TR.cis TD.h {color:red;border-width:1px 1px 1px 0;} TR.cis TD.f {border-width:1px 1px 1px 1px;} TR.cis TD.hf {color:red;border-width:1px 1px 1px 1px;} TD.b {border-style:none;background:transparent;line-height:50%;} TD.bt {border-width:1px 0 0 0;background:transparent;line-height:50%;} TR.o TD {background:#F0F0F0;}TABLE.it {border-style:none;}TABLE.it TD,TABLE.it TH {border-style:none;}</STYLE></HEAD><BODY><TABLE CLASS="hdft" CELLSPACING="0" WIDTH="100%"><TR><TH CLASS="tl"><A HREF="http://www.eclemma.org/">EMMA</A> Coverage Report (generated Fri Feb 20 18:44:54 GMT 2009)</TH></TR><TR><TD CLASS="nv">[<A HREF="../xslUnitTestCoverage.html">all classes</A>][<A HREF="74.html">org.eclipse.wst.sse.core.internal.tasks</A>]</TD></TR></TABLE><H2>COVERAGE SUMMARY FOR SOURCE FILE [<SPAN CLASS="in">StructuredFileTaskScanner.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>StructuredFileTaskScanner.java</TD><TD CLASS="h">0%   (0/2)</TD><TD CLASS="h">0%   (0/16)</TD><TD CLASS="h">0%   (0/655)</TD><TD CLASS="h">0%   (0/141)</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">StructuredFileTaskScanner</A></TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/13)</TD><TD CLASS="h">0%   (0/590)</TD><TD CLASS="h">0%   (0/128)</TD></TR><TR><TD CLASS="f"><A HREF="#0">StructuredFileTaskScanner (): void</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/28)</TD><TD CLASS="h">0%   (0/7)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#2">createInitialMarkerAttributes (String, int, int, int, int): Map</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/79)</TD><TD CLASS="h">0%   (0/14)</TD></TR><TR><TD CLASS="f"><A HREF="#3">detectCharset (IFile): String</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/16)</TD><TD CLASS="h">0%   (0/5)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#4">findTasks (IDocument, TaskTag [], IStructuredDocumentRegion, ITextRegion): void</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/109)</TD><TD CLASS="h">0%   (0/22)</TD></TR><TR><TD CLASS="f"><A HREF="#5">findTasks (IFile, TaskTag [], IProgressMonitor): void</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/154)</TD><TD CLASS="h">0%   (0/35)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#6">getCommentedText (IDocument, int, int): String</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/5)</TD><TD CLASS="h">0%   (0/1)</TD></TR><TR><TD CLASS="f"><A HREF="#7">getMarkerType (): String</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/8)</TD><TD CLASS="h">0%   (0/3)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#8">scan (IFile, TaskTag [], IProgressMonitor): Map []</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/53)</TD><TD CLASS="h">0%   (0/10)</TD></TR><TR><TD CLASS="f"><A HREF="#9">setDocumentContent (IDocument, InputStream, String): void</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/58)</TD><TD CLASS="h">0%   (0/16)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#a">setInitializationData (IConfigurationElement, String, Object): void</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/10)</TD><TD CLASS="h">0%   (0/3)</TD></TR><TR><TD CLASS="f"><A HREF="#b">shouldScan (IResource): boolean</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/15)</TD><TD CLASS="h">0%   (0/2)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#c">shutdown (IProject): void</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/16)</TD><TD CLASS="h">0%   (0/3)</TD></TR><TR><TD CLASS="f"><A HREF="#d">startup (IProject): void</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/39)</TD><TD CLASS="h">0%   (0/7)</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">StructuredFileTaskScanner$1</A></TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/3)</TD><TD CLASS="h">0%   (0/65)</TD><TD CLASS="h">0%   (0/14)</TD></TR><TR><TD CLASS="f"><A HREF="#e">StructuredFileTaskScanner$1 (StructuredFileTaskScanner, IDocument, TaskTag []...</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/15)</TD><TD CLASS="h">0%   (0/2)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#10">nodeParsed (IStructuredDocumentRegion): void</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/49)</TD><TD CLASS="h">0%   (0/11)</TD></TR><TR><TD CLASS="f"><A HREF="#11">resetNodes (): void</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/1)</TD></TR></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.io.BufferedReader;</TD></TR><TR><TD CLASS="l">16</TD><TD>import java.io.IOException;</TD></TR><TR><TD CLASS="l">17</TD><TD>import java.io.InputStream;</TD></TR><TR><TD CLASS="l">18</TD><TD>import java.io.InputStreamReader;</TD></TR><TR><TD CLASS="l">19</TD><TD>import java.io.Reader;</TD></TR><TR><TD CLASS="l">20</TD><TD>import java.nio.charset.CharacterCodingException;</TD></TR><TR><TD CLASS="l">21</TD><TD>import java.util.ArrayList;</TD></TR><TR><TD CLASS="l">22</TD><TD>import java.util.HashMap;</TD></TR><TR><TD CLASS="l">23</TD><TD>import java.util.List;</TD></TR><TR><TD CLASS="l">24</TD><TD>import java.util.Locale;</TD></TR><TR><TD CLASS="l">25</TD><TD>import java.util.Map;</TD></TR><TR><TD CLASS="l">26</TD><TD> </TD></TR><TR><TD CLASS="l">27</TD><TD>import org.eclipse.core.resources.IFile;</TD></TR><TR><TD CLASS="l">28</TD><TD>import org.eclipse.core.resources.IMarker;</TD></TR><TR><TD CLASS="l">29</TD><TD>import org.eclipse.core.resources.IProject;</TD></TR><TR><TD CLASS="l">30</TD><TD>import org.eclipse.core.resources.IResource;</TD></TR><TR><TD CLASS="l">31</TD><TD>import org.eclipse.core.resources.ResourcesPlugin;</TD></TR><TR><TD CLASS="l">32</TD><TD>import org.eclipse.core.runtime.CoreException;</TD></TR><TR><TD CLASS="l">33</TD><TD>import org.eclipse.core.runtime.IConfigurationElement;</TD></TR><TR><TD CLASS="l">34</TD><TD>import org.eclipse.core.runtime.IExecutableExtension;</TD></TR><TR><TD CLASS="l">35</TD><TD>import org.eclipse.core.runtime.IProgressMonitor;</TD></TR><TR><TD CLASS="l">36</TD><TD>import org.eclipse.jface.text.BadLocationException;</TD></TR><TR><TD CLASS="l">37</TD><TD>import org.eclipse.jface.text.Document;</TD></TR><TR><TD CLASS="l">38</TD><TD>import org.eclipse.jface.text.IDocument;</TD></TR><TR><TD CLASS="l">39</TD><TD>import org.eclipse.jface.text.IRegion;</TD></TR><TR><TD CLASS="l">40</TD><TD>import org.eclipse.wst.sse.core.internal.Logger;</TD></TR><TR><TD CLASS="l">41</TD><TD>import org.eclipse.wst.sse.core.internal.document.DocumentReader;</TD></TR><TR><TD CLASS="l">42</TD><TD>import org.eclipse.wst.sse.core.internal.ltk.modelhandler.IModelHandler;</TD></TR><TR><TD CLASS="l">43</TD><TD>import org.eclipse.wst.sse.core.internal.ltk.parser.RegionParser;</TD></TR><TR><TD CLASS="l">44</TD><TD>import org.eclipse.wst.sse.core.internal.ltk.parser.StructuredDocumentRegionHandler;</TD></TR><TR><TD CLASS="l">45</TD><TD>import org.eclipse.wst.sse.core.internal.ltk.parser.StructuredDocumentRegionParser;</TD></TR><TR><TD CLASS="l">46</TD><TD>import org.eclipse.wst.sse.core.internal.modelhandler.ModelHandlerRegistry;</TD></TR><TR><TD CLASS="l">47</TD><TD>import org.eclipse.wst.sse.core.internal.provisional.document.IEncodedDocument;</TD></TR><TR><TD CLASS="l">48</TD><TD>import org.eclipse.wst.sse.core.internal.provisional.tasks.IFileTaskScanner;</TD></TR><TR><TD CLASS="l">49</TD><TD>import org.eclipse.wst.sse.core.internal.provisional.tasks.TaskTag;</TD></TR><TR><TD CLASS="l">50</TD><TD>import org.eclipse.wst.sse.core.internal.provisional.text.IStructuredDocument;</TD></TR><TR><TD CLASS="l">51</TD><TD>import org.eclipse.wst.sse.core.internal.provisional.text.IStructuredDocumentRegion;</TD></TR><TR><TD CLASS="l">52</TD><TD>import org.eclipse.wst.sse.core.internal.provisional.text.ITextRegion;</TD></TR><TR><TD CLASS="l">53</TD><TD>import org.eclipse.wst.sse.core.internal.provisional.text.ITextRegionList;</TD></TR><TR><TD CLASS="l">54</TD><TD> </TD></TR><TR><TD CLASS="l">55</TD><TD>/**</TD></TR><TR><TD CLASS="l">56</TD><TD> * A delegate to create IMarker.TASKs for &#34;todos&#34; and similar comments.</TD></TR><TR><TD CLASS="l">57</TD><TD> */</TD></TR><TR><TD CLASS="l">58</TD><TD>public abstract class StructuredFileTaskScanner implements IFileTaskScanner, IExecutableExtension {</TD></TR><TR><TD CLASS="l">59</TD><TD>        // the list of attributes for the new tasks for the current file</TD></TR><TR CLASS="z"><TD CLASS="l">60</TD><TD>        protected List fNewMarkerAttributeMaps = null;</TD></TR><TR><TD CLASS="l">61</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">62</TD><TD>        List oldMarkers = null;</TD></TR><TR><TD CLASS="l"><A NAME="0">63</A></TD><TD>        private long time0;</TD></TR><TR><TD CLASS="l">64</TD><TD>        private String runtimeMarkerType;</TD></TR><TR><TD CLASS="l">65</TD><TD> </TD></TR><TR><TD CLASS="l">66</TD><TD>        public StructuredFileTaskScanner() {</TD></TR><TR CLASS="z"><TD CLASS="l">67</TD><TD>                super();</TD></TR><TR CLASS="z"><TD CLASS="l">68</TD><TD>                fNewMarkerAttributeMaps = new ArrayList();</TD></TR><TR CLASS="z"><TD CLASS="l">69</TD><TD>                if (Logger.DEBUG_TASKS) {</TD></TR><TR CLASS="z"><TD CLASS="l">70</TD><TD>                        System.out.println(getClass().getName() + &#34; instance created&#34;); //$NON-NLS-1$</TD></TR><TR><TD CLASS="l">71</TD><TD>                }</TD></TR><TR CLASS="z"><TD CLASS="l">72</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>         * Returns the attributes with which a newly created marker will be</TD></TR><TR><TD CLASS="l">76</TD><TD>         * initialized. Modified from the method in MarkerRulerAction</TD></TR><TR><TD CLASS="l"><A NAME="2">77</A></TD><TD>         * </TD></TR><TR><TD CLASS="l">78</TD><TD>         * @return the initial marker attributes</TD></TR><TR><TD CLASS="l">79</TD><TD>         */</TD></TR><TR><TD CLASS="l">80</TD><TD>        protected Map createInitialMarkerAttributes(String text, int documentLine, int startOffset, int length, int priority) {</TD></TR><TR CLASS="z"><TD CLASS="l">81</TD><TD>                Map attributes = new HashMap(6);</TD></TR><TR><TD CLASS="l">82</TD><TD>                // marker line numbers are 1-based</TD></TR><TR CLASS="z"><TD CLASS="l">83</TD><TD>                attributes.put(IMarker.LINE_NUMBER, new Integer(documentLine + 1));</TD></TR><TR CLASS="z"><TD CLASS="l">84</TD><TD>                attributes.put(IMarker.TASK, getMarkerType());</TD></TR><TR CLASS="z"><TD CLASS="l">85</TD><TD>                attributes.put(IMarker.CHAR_START, new Integer(startOffset));</TD></TR><TR CLASS="z"><TD CLASS="l">86</TD><TD>                attributes.put(IMarker.CHAR_END, new Integer(startOffset + length));</TD></TR><TR CLASS="z"><TD CLASS="l">87</TD><TD>                attributes.put(IMarker.MESSAGE, text);</TD></TR><TR CLASS="z"><TD CLASS="l">88</TD><TD>                attributes.put(IMarker.USER_EDITABLE, Boolean.FALSE);</TD></TR><TR><TD CLASS="l">89</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">90</TD><TD>                switch (priority) {</TD></TR><TR><TD CLASS="l">91</TD><TD>                        case IMarker.PRIORITY_HIGH : {</TD></TR><TR CLASS="z"><TD CLASS="l">92</TD><TD>                                attributes.put(IMarker.PRIORITY, new Integer(IMarker.PRIORITY_HIGH));</TD></TR><TR><TD CLASS="l">93</TD><TD>                        }</TD></TR><TR CLASS="z"><TD CLASS="l">94</TD><TD>                                break;</TD></TR><TR><TD CLASS="l">95</TD><TD>                        case IMarker.PRIORITY_LOW : {</TD></TR><TR CLASS="z"><TD CLASS="l">96</TD><TD>                                attributes.put(IMarker.PRIORITY, new Integer(IMarker.PRIORITY_LOW));</TD></TR><TR><TD CLASS="l">97</TD><TD>                        }</TD></TR><TR CLASS="z"><TD CLASS="l">98</TD><TD>                                break;</TD></TR><TR><TD CLASS="l">99</TD><TD>                        default : {</TD></TR><TR CLASS="z"><TD CLASS="l">100</TD><TD>                                attributes.put(IMarker.PRIORITY, new Integer(IMarker.PRIORITY_NORMAL));</TD></TR><TR><TD CLASS="l">101</TD><TD>                        }</TD></TR><TR><TD CLASS="l">102</TD><TD>                }</TD></TR><TR><TD CLASS="l">103</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">104</TD><TD>                return attributes;</TD></TR><TR><TD CLASS="l">105</TD><TD>        }</TD></TR><TR><TD CLASS="l">106</TD><TD> </TD></TR><TR><TD CLASS="l">107</TD><TD>        /*</TD></TR><TR><TD CLASS="l">108</TD><TD>         * (non-Javadoc)</TD></TR><TR><TD CLASS="l"><A NAME="7">109</A></TD><TD>         * </TD></TR><TR><TD CLASS="l">110</TD><TD>         * @see org.eclipse.wst.sse.core.internal.provisional.tasks.IFileTaskScanner#getMarkerType()</TD></TR><TR><TD CLASS="l">111</TD><TD>         */</TD></TR><TR><TD CLASS="l">112</TD><TD>        public String getMarkerType() {</TD></TR><TR CLASS="z"><TD CLASS="l">113</TD><TD>                if (runtimeMarkerType != null)</TD></TR><TR CLASS="z"><TD CLASS="l">114</TD><TD>                        return runtimeMarkerType;</TD></TR><TR><TD CLASS="l">115</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l"><A NAME="3">116</A></TD><TD>                return org.eclipse.core.resources.IMarker.TASK;</TD></TR><TR><TD CLASS="l">117</TD><TD>        }</TD></TR><TR><TD CLASS="l">118</TD><TD> </TD></TR><TR><TD CLASS="l">119</TD><TD>        private String detectCharset(IFile file) {</TD></TR><TR CLASS="z"><TD CLASS="l">120</TD><TD>                if (file.getType() == IResource.FILE &amp;&amp; file.isAccessible()) {</TD></TR><TR><TD CLASS="l">121</TD><TD>                        try {</TD></TR><TR CLASS="z"><TD CLASS="l">122</TD><TD>                                return file.getCharset(true);</TD></TR><TR><TD CLASS="l">123</TD><TD>                        }</TD></TR><TR CLASS="z"><TD CLASS="l">124</TD><TD>                        catch (CoreException e) {</TD></TR><TR CLASS="z"><TD CLASS="l">125</TD><TD>                                Logger.logException(e);</TD></TR><TR><TD CLASS="l">126</TD><TD>                        }</TD></TR><TR><TD CLASS="l">127</TD><TD>                }</TD></TR><TR CLASS="z"><TD CLASS="l">128</TD><TD>                return ResourcesPlugin.getEncoding();</TD></TR><TR><TD CLASS="l">129</TD><TD>        }</TD></TR><TR><TD CLASS="l">130</TD><TD> </TD></TR><TR><TD CLASS="l">131</TD><TD>        /**</TD></TR><TR><TD CLASS="l">132</TD><TD>         * @param document</TD></TR><TR><TD CLASS="l"><A NAME="4">133</A></TD><TD>         * @param documentRegion</TD></TR><TR><TD CLASS="l">134</TD><TD>         * @param comment</TD></TR><TR><TD CLASS="l">135</TD><TD>         */</TD></TR><TR><TD CLASS="l">136</TD><TD>        protected void findTasks(IDocument document, TaskTag[] taskTags, IStructuredDocumentRegion documentRegion, ITextRegion comment) {</TD></TR><TR CLASS="z"><TD CLASS="l">137</TD><TD>                if (isCommentRegion(documentRegion, comment)) {</TD></TR><TR CLASS="z"><TD CLASS="l">138</TD><TD>                        int startOffset = documentRegion.getStartOffset(comment);</TD></TR><TR CLASS="z"><TD CLASS="l">139</TD><TD>                        int endOffset = documentRegion.getTextEndOffset(comment);</TD></TR><TR><TD CLASS="l">140</TD><TD>                        try {</TD></TR><TR CLASS="z"><TD CLASS="l">141</TD><TD>                                int startLine = document.getLineOfOffset(startOffset);</TD></TR><TR CLASS="z"><TD CLASS="l">142</TD><TD>                                int endLine = document.getLineOfOffset(endOffset);</TD></TR><TR CLASS="z"><TD CLASS="l">143</TD><TD>                                for (int lineNumber = startLine; lineNumber &lt;= endLine; lineNumber++) {</TD></TR><TR CLASS="z"><TD CLASS="l">144</TD><TD>                                        IRegion line = document.getLineInformation(lineNumber);</TD></TR><TR CLASS="z"><TD CLASS="l">145</TD><TD>                                        int begin = Math.max(startOffset, line.getOffset());</TD></TR><TR CLASS="z"><TD CLASS="l">146</TD><TD>                                        int end = Math.min(endOffset, line.getOffset() + line.getLength());</TD></TR><TR CLASS="z"><TD CLASS="l">147</TD><TD>                                        int length = end - begin;</TD></TR><TR><TD CLASS="l">148</TD><TD> </TD></TR><TR><TD CLASS="l">149</TD><TD>                                        /* XXX: This generates a lot of garbage objects */</TD></TR><TR><TD CLASS="l">150</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">151</TD><TD>                                        String commentedText = getCommentedText(document, begin, length);</TD></TR><TR CLASS="z"><TD CLASS="l">152</TD><TD>                                        String comparisonText = commentedText.toLowerCase(Locale.ENGLISH);</TD></TR><TR><TD CLASS="l">153</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">154</TD><TD>                                        for (int i = 0; i &lt; taskTags.length; i++) {</TD></TR><TR CLASS="z"><TD CLASS="l">155</TD><TD>                                                int tagIndex = comparisonText.indexOf(taskTags[i].getTag().toLowerCase(Locale.ENGLISH));</TD></TR><TR CLASS="z"><TD CLASS="l">156</TD><TD>                                                if (tagIndex &gt;= 0) {</TD></TR><TR CLASS="z"><TD CLASS="l">157</TD><TD>                                                        String markerDescription = commentedText.substring(tagIndex);</TD></TR><TR CLASS="z"><TD CLASS="l">158</TD><TD>                                                        int markerOffset = begin + tagIndex;</TD></TR><TR CLASS="z"><TD CLASS="l">159</TD><TD>                                                        int markerLength = end - markerOffset;</TD></TR><TR CLASS="z"><TD CLASS="l">160</TD><TD>                                                        fNewMarkerAttributeMaps.add(createInitialMarkerAttributes(markerDescription, lineNumber, markerOffset, markerLength, taskTags[i].getPriority()));</TD></TR><TR><TD CLASS="l">161</TD><TD>                                                }</TD></TR><TR><TD CLASS="l">162</TD><TD>                                        }</TD></TR><TR><TD CLASS="l">163</TD><TD>                                }</TD></TR><TR><TD CLASS="l">164</TD><TD>                        }</TD></TR><TR CLASS="z"><TD CLASS="l">165</TD><TD>                        catch (BadLocationException e) {</TD></TR><TR CLASS="z"><TD CLASS="l">166</TD><TD>                                Logger.logException(e);</TD></TR><TR><TD CLASS="l">167</TD><TD>                        }</TD></TR><TR><TD CLASS="l">168</TD><TD>                }</TD></TR><TR CLASS="z"><TD CLASS="l"><A NAME="5">169</A></TD><TD>        }</TD></TR><TR><TD CLASS="l">170</TD><TD> </TD></TR><TR><TD CLASS="l">171</TD><TD>        private void findTasks(IFile file, final TaskTag[] taskTags, final IProgressMonitor monitor) {</TD></TR><TR><TD CLASS="l">172</TD><TD>                try {</TD></TR><TR CLASS="z"><TD CLASS="l">173</TD><TD>                        IModelHandler handler = ModelHandlerRegistry.getInstance().getHandlerFor(file);</TD></TR><TR><TD CLASS="l">174</TD><TD> </TD></TR><TR><TD CLASS="l">175</TD><TD>                        // records if the optimized streamish parse was possible</TD></TR><TR CLASS="z"><TD CLASS="l">176</TD><TD>                        boolean didStreamParse = false;</TD></TR><TR CLASS="z"><TD CLASS="l">177</TD><TD>                        final IEncodedDocument defaultDocument = handler.getDocumentLoader().createNewStructuredDocument();</TD></TR><TR CLASS="z"><TD CLASS="l">178</TD><TD>                        if (defaultDocument instanceof IStructuredDocument) {</TD></TR><TR CLASS="z"><TD CLASS="l">179</TD><TD>                                RegionParser parser = ((IStructuredDocument) defaultDocument).getParser();</TD></TR><TR CLASS="z"><TD CLASS="l">180</TD><TD>                                if (parser instanceof StructuredDocumentRegionParser) {</TD></TR><TR CLASS="z"><TD CLASS="l">181</TD><TD>                                        didStreamParse = true;</TD></TR><TR CLASS="z"><TD CLASS="l">182</TD><TD>                                        String charset = detectCharset(file);</TD></TR><TR CLASS="z"><TD CLASS="l">183</TD><TD>                                        StructuredDocumentRegionParser documentParser = (StructuredDocumentRegionParser) parser;</TD></TR><TR CLASS="z"><TD CLASS="l"><A NAME="e">184</A></TD><TD>                                        final IDocument textDocument = new Document();</TD></TR><TR CLASS="z"><TD CLASS="l">185</TD><TD>                                        setDocumentContent(textDocument, file.getContents(true), charset);</TD></TR><TR CLASS="z"><TD CLASS="l"><A NAME="10">186</A></TD><TD>                                        monitor.beginTask(&#34;&#34;, textDocument.getLength());</TD></TR><TR CLASS="z"><TD CLASS="l">187</TD><TD>                                        documentParser.reset(new DocumentReader(textDocument));</TD></TR><TR CLASS="z"><TD CLASS="l">188</TD><TD>                                        documentParser.addStructuredDocumentRegionHandler(new StructuredDocumentRegionHandler() {</TD></TR><TR><TD CLASS="l">189</TD><TD>                                                public void nodeParsed(IStructuredDocumentRegion documentRegion) {</TD></TR><TR CLASS="z"><TD CLASS="l">190</TD><TD>                                                        ITextRegionList regions = documentRegion.getRegions();</TD></TR><TR CLASS="z"><TD CLASS="l">191</TD><TD>                                                        for (int j = 0; j &lt; regions.size(); j++) {</TD></TR><TR CLASS="z"><TD CLASS="l">192</TD><TD>                                                                ITextRegion comment = regions.get(j);</TD></TR><TR CLASS="z"><TD CLASS="l">193</TD><TD>                                                                findTasks(textDocument, taskTags, documentRegion, comment);</TD></TR><TR><TD CLASS="l">194</TD><TD>                                                        }</TD></TR><TR><TD CLASS="l">195</TD><TD>                                                        // disconnect the document regions</TD></TR><TR CLASS="z"><TD CLASS="l">196</TD><TD>                                                        if (documentRegion.getPrevious() != null) {</TD></TR><TR CLASS="z"><TD CLASS="l">197</TD><TD>                                                                documentRegion.getPrevious().setPrevious(null);</TD></TR><TR CLASS="z"><TD CLASS="l">198</TD><TD>                                                                documentRegion.getPrevious().setNext(null);</TD></TR><TR><TD CLASS="l">199</TD><TD>                                                        }</TD></TR><TR CLASS="z"><TD CLASS="l">200</TD><TD>                                                        if (monitor.isCanceled()) {</TD></TR><TR CLASS="z"><TD CLASS="l">201</TD><TD>                                                                textDocument.set(&#34;&#34;); //$NON-NLS-1$</TD></TR><TR><TD CLASS="l">202</TD><TD>                                                        }</TD></TR><TR CLASS="z"><TD CLASS="l"><A NAME="11">203</A></TD><TD>                                                        monitor.worked(documentRegion.getLength());</TD></TR><TR CLASS="z"><TD CLASS="l">204</TD><TD>                                                }</TD></TR><TR><TD CLASS="l">205</TD><TD> </TD></TR><TR><TD CLASS="l">206</TD><TD>                                                public void resetNodes() {</TD></TR><TR CLASS="z"><TD CLASS="l">207</TD><TD>                                                }</TD></TR><TR><TD CLASS="l">208</TD><TD>                                        });</TD></TR><TR CLASS="z"><TD CLASS="l">209</TD><TD>                                        documentParser.getDocumentRegions();</TD></TR><TR><TD CLASS="l">210</TD><TD>                                }</TD></TR><TR><TD CLASS="l">211</TD><TD>                        }</TD></TR><TR CLASS="z"><TD CLASS="l">212</TD><TD>                        if (!didStreamParse) {</TD></TR><TR><TD CLASS="l">213</TD><TD>                                // Use a StructuredDocument</TD></TR><TR CLASS="z"><TD CLASS="l">214</TD><TD>                                IEncodedDocument document = handler.getDocumentLoader().createNewStructuredDocument(file);</TD></TR><TR CLASS="z"><TD CLASS="l">215</TD><TD>                                monitor.beginTask(&#34;&#34;, document.getLength());</TD></TR><TR CLASS="z"><TD CLASS="l">216</TD><TD>                                if (document instanceof IStructuredDocument) {</TD></TR><TR CLASS="z"><TD CLASS="l">217</TD><TD>                                        IStructuredDocumentRegion documentRegion = ((IStructuredDocument) document).getFirstStructuredDocumentRegion();</TD></TR><TR CLASS="z"><TD CLASS="l">218</TD><TD>                                        while (documentRegion != null) {</TD></TR><TR CLASS="z"><TD CLASS="l">219</TD><TD>                                                ITextRegionList regions = documentRegion.getRegions();</TD></TR><TR CLASS="z"><TD CLASS="l">220</TD><TD>                                                for (int j = 0; j &lt; regions.size(); j++) {</TD></TR><TR CLASS="z"><TD CLASS="l">221</TD><TD>                                                        ITextRegion comment = regions.get(j);</TD></TR><TR CLASS="z"><TD CLASS="l">222</TD><TD>                                                        findTasks(document, taskTags, documentRegion, comment);</TD></TR><TR><TD CLASS="l">223</TD><TD>                                                }</TD></TR><TR CLASS="z"><TD CLASS="l">224</TD><TD>                                                monitor.worked(documentRegion.getLength());</TD></TR><TR CLASS="z"><TD CLASS="l">225</TD><TD>                                                documentRegion = documentRegion.getNext();</TD></TR><TR><TD CLASS="l">226</TD><TD>                                        }</TD></TR><TR><TD CLASS="l">227</TD><TD>                                }</TD></TR><TR><TD CLASS="l">228</TD><TD>                        }</TD></TR><TR><TD CLASS="l">229</TD><TD>                }</TD></TR><TR CLASS="z"><TD CLASS="l">230</TD><TD>                catch (CoreException e) {</TD></TR><TR CLASS="z"><TD CLASS="l">231</TD><TD>                        Logger.logException(&#34;Exception with &#34; + file.getFullPath().toString(), e); //$NON-NLS-1$</TD></TR><TR><TD CLASS="l">232</TD><TD>                }</TD></TR><TR CLASS="z"><TD CLASS="l">233</TD><TD>                catch (CharacterCodingException e) {</TD></TR><TR CLASS="z"><TD CLASS="l">234</TD><TD>                        Logger.log(Logger.INFO, &#34;StructuredFileTaskScanner encountered CharacterCodingException reading &#34; + file.getFullPath()); //$NON-NLS-1$</TD></TR><TR><TD CLASS="l">235</TD><TD>                }</TD></TR><TR CLASS="z"><TD CLASS="l">236</TD><TD>                catch (Exception e) {</TD></TR><TR CLASS="z"><TD CLASS="l">237</TD><TD>                        Logger.logException(&#34;Exception with &#34; + file.getFullPath().toString(), e); //$NON-NLS-1$</TD></TR><TR><TD CLASS="l">238</TD><TD>                }</TD></TR><TR CLASS="z"><TD CLASS="l"><A NAME="6">239</A></TD><TD>                monitor.done();</TD></TR><TR CLASS="z"><TD CLASS="l">240</TD><TD>        }</TD></TR><TR><TD CLASS="l">241</TD><TD> </TD></TR><TR><TD CLASS="l">242</TD><TD>        protected String getCommentedText(IDocument document, int begin, int length) throws BadLocationException {</TD></TR><TR CLASS="z"><TD CLASS="l">243</TD><TD>                return document.get(begin, length);</TD></TR><TR><TD CLASS="l">244</TD><TD>        }</TD></TR><TR><TD CLASS="l"><A NAME="8">245</A></TD><TD> </TD></TR><TR><TD CLASS="l">246</TD><TD>        protected abstract boolean isCommentRegion(IStructuredDocumentRegion region, ITextRegion textRegion);</TD></TR><TR><TD CLASS="l">247</TD><TD> </TD></TR><TR><TD CLASS="l">248</TD><TD>        public synchronized Map[] scan(IFile file, TaskTag[] taskTags, IProgressMonitor monitor) {</TD></TR><TR CLASS="z"><TD CLASS="l">249</TD><TD>                fNewMarkerAttributeMaps.clear();</TD></TR><TR CLASS="z"><TD CLASS="l">250</TD><TD>                if (monitor.isCanceled() || !shouldScan(file)) {</TD></TR><TR CLASS="z"><TD CLASS="l">251</TD><TD>                        return new Map[0];</TD></TR><TR><TD CLASS="l">252</TD><TD>                }</TD></TR><TR CLASS="z"><TD CLASS="l">253</TD><TD>                if (Logger.DEBUG_TASKSPERF) {</TD></TR><TR CLASS="z"><TD CLASS="l">254</TD><TD>                        time0 = System.currentTimeMillis();</TD></TR><TR><TD CLASS="l">255</TD><TD>                }</TD></TR><TR CLASS="z"><TD CLASS="l">256</TD><TD>                if (taskTags.length &gt; 0) {</TD></TR><TR CLASS="z"><TD CLASS="l">257</TD><TD>                        findTasks(file, taskTags, monitor);</TD></TR><TR><TD CLASS="l">258</TD><TD>                }</TD></TR><TR CLASS="z"><TD CLASS="l">259</TD><TD>                if (Logger.DEBUG_TASKSPERF) {</TD></TR><TR CLASS="z"><TD CLASS="l">260</TD><TD>                        System.out.println(&#34;&#34; + (System.currentTimeMillis() - time0) + &#34;ms for &#34; + file.getFullPath()); //$NON-NLS-1$ //$NON-NLS-2$</TD></TR><TR><TD CLASS="l">261</TD><TD>                }</TD></TR><TR CLASS="z"><TD CLASS="l">262</TD><TD>                return (Map[]) fNewMarkerAttributeMaps.toArray(new Map[fNewMarkerAttributeMaps.size()]);</TD></TR><TR><TD CLASS="l">263</TD><TD>        }</TD></TR><TR><TD CLASS="l">264</TD><TD> </TD></TR><TR><TD CLASS="l"><A NAME="9">265</A></TD><TD>        /**</TD></TR><TR><TD CLASS="l">266</TD><TD>         * Sets the document content from this stream and closes the stream</TD></TR><TR><TD CLASS="l">267</TD><TD>         */</TD></TR><TR><TD CLASS="l">268</TD><TD>        protected void setDocumentContent(IDocument document, InputStream contentStream, String charset) {</TD></TR><TR CLASS="z"><TD CLASS="l">269</TD><TD>                Reader in = null;</TD></TR><TR><TD CLASS="l">270</TD><TD>                try {</TD></TR><TR CLASS="z"><TD CLASS="l">271</TD><TD>                        in = new BufferedReader(new InputStreamReader(contentStream, charset), 2048);</TD></TR><TR CLASS="z"><TD CLASS="l">272</TD><TD>                        StringBuffer buffer = new StringBuffer(2048);</TD></TR><TR CLASS="z"><TD CLASS="l">273</TD><TD>                        char[] readBuffer = new char[2048];</TD></TR><TR CLASS="z"><TD CLASS="l">274</TD><TD>                        int n = in.read(readBuffer);</TD></TR><TR CLASS="z"><TD CLASS="l">275</TD><TD>                        while (n &gt; 0) {</TD></TR><TR CLASS="z"><TD CLASS="l">276</TD><TD>                                buffer.append(readBuffer, 0, n);</TD></TR><TR CLASS="z"><TD CLASS="l">277</TD><TD>                                n = in.read(readBuffer);</TD></TR><TR><TD CLASS="l">278</TD><TD>                        }</TD></TR><TR CLASS="z"><TD CLASS="l">279</TD><TD>                        document.set(buffer.toString());</TD></TR><TR><TD CLASS="l">280</TD><TD>                }</TD></TR><TR CLASS="z"><TD CLASS="l">281</TD><TD>                catch (IOException x) {</TD></TR><TR><TD CLASS="l">282</TD><TD>                }</TD></TR><TR CLASS="z"><TD CLASS="l">283</TD><TD>                finally {</TD></TR><TR CLASS="z"><TD CLASS="l">284</TD><TD>                        if (in != null) {</TD></TR><TR><TD CLASS="l">285</TD><TD>                                try {</TD></TR><TR CLASS="z"><TD CLASS="l">286</TD><TD>                                        in.close();</TD></TR><TR><TD CLASS="l">287</TD><TD>                                }</TD></TR><TR CLASS="z"><TD CLASS="l">288</TD><TD>                                catch (IOException x) {</TD></TR><TR><TD CLASS="l">289</TD><TD>                                }</TD></TR><TR><TD CLASS="l">290</TD><TD>                        }</TD></TR><TR CLASS="z"><TD CLASS="l">291</TD><TD>                }</TD></TR><TR CLASS="z"><TD CLASS="l">292</TD><TD>        }</TD></TR><TR><TD CLASS="l">293</TD><TD> </TD></TR><TR><TD CLASS="l">294</TD><TD>        /*</TD></TR><TR><TD CLASS="l">295</TD><TD>         * (non-Javadoc)</TD></TR><TR><TD CLASS="l">296</TD><TD>         * </TD></TR><TR><TD CLASS="l"><A NAME="a">297</A></TD><TD>         * @see org.eclipse.core.runtime.IExecutableExtension#setInitializationData(org.eclipse.core.runtime.IConfigurationElement,</TD></TR><TR><TD CLASS="l">298</TD><TD>         *      java.lang.String, java.lang.Object)</TD></TR><TR><TD CLASS="l">299</TD><TD>         */</TD></TR><TR><TD CLASS="l">300</TD><TD>        public void setInitializationData(IConfigurationElement config, String propertyName, Object data) throws CoreException {</TD></TR><TR CLASS="z"><TD CLASS="l">301</TD><TD>                if (data != null &amp;&amp; data instanceof String) {</TD></TR><TR CLASS="z"><TD CLASS="l">302</TD><TD>                        runtimeMarkerType = data.toString();</TD></TR><TR><TD CLASS="l">303</TD><TD>                }</TD></TR><TR CLASS="z"><TD CLASS="l"><A NAME="b">304</A></TD><TD>        }</TD></TR><TR><TD CLASS="l">305</TD><TD> </TD></TR><TR><TD CLASS="l">306</TD><TD>        boolean shouldScan(IResource r) {</TD></TR><TR><TD CLASS="l">307</TD><TD>                // skip &#34;dot&#34; files</TD></TR><TR CLASS="z"><TD CLASS="l">308</TD><TD>                String s = r.getName();</TD></TR><TR CLASS="z"><TD CLASS="l"><A NAME="c">309</A></TD><TD>                return s.length() == 0 || s.charAt(0) != '.';</TD></TR><TR><TD CLASS="l">310</TD><TD>        }</TD></TR><TR><TD CLASS="l">311</TD><TD> </TD></TR><TR><TD CLASS="l">312</TD><TD>        public void shutdown(IProject project) {</TD></TR><TR CLASS="z"><TD CLASS="l">313</TD><TD>                if (Logger.DEBUG_TASKS) {</TD></TR><TR CLASS="z"><TD CLASS="l">314</TD><TD>                        System.out.println(this + &#34; shutdown for &#34; + project.getName()); //$NON-NLS-1$</TD></TR><TR><TD CLASS="l"><A NAME="d">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>        public void startup(IProject project) {</TD></TR><TR CLASS="z"><TD CLASS="l">319</TD><TD>                if (Logger.DEBUG_TASKS) {</TD></TR><TR CLASS="z"><TD CLASS="l">320</TD><TD>                        System.out.println(this + &#34; startup for &#34; + project.getName()); //$NON-NLS-1$</TD></TR><TR><TD CLASS="l">321</TD><TD>                }</TD></TR><TR CLASS="z"><TD CLASS="l">322</TD><TD>                if (Logger.DEBUG_TASKSPERF) {</TD></TR><TR CLASS="z"><TD CLASS="l">323</TD><TD>                        time0 = System.currentTimeMillis();</TD></TR><TR><TD CLASS="l">324</TD><TD>                }</TD></TR><TR CLASS="z"><TD CLASS="l">325</TD><TD>                if (Logger.DEBUG_TASKSPERF) {</TD></TR><TR CLASS="z"><TD CLASS="l">326</TD><TD>                        System.out.println(&#34;&#34; + (System.currentTimeMillis() - time0) + &#34;ms loading prefs for &#34; + project.getName()); //$NON-NLS-1$ //$NON-NLS-2$</TD></TR><TR><TD CLASS="l">327</TD><TD>                }</TD></TR><TR CLASS="z"><TD CLASS="l">328</TD><TD>        }</TD></TR><TR><TD CLASS="l">329</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>