blob: c43168a2571ea476186b76bda544c32f880b012e [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="95.html">org.eclipse.wst.xml.core.internal.validation.core</A>]</TD></TR></TABLE><H2>COVERAGE SUMMARY FOR SOURCE FILE [<SPAN CLASS="in">Helper.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>Helper.java</TD><TD CLASS="h">0%   (0/2)</TD><TD CLASS="h">0%   (0/10)</TD><TD CLASS="h">0%   (0/217)</TD><TD CLASS="h">0%   (0/49)</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">Helper</A></TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/8)</TD><TD CLASS="h">0%   (0/157)</TD><TD CLASS="h">0%   (0/38)</TD></TR><TR><TD CLASS="f"><A HREF="#0">Helper (): void</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/34)</TD><TD CLASS="h">0%   (0/6)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#2">deleteMarkers (IResource, String, String, Object): void</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/27)</TD><TD CLASS="h">0%   (0/6)</TD></TR><TR><TD CLASS="f"><A HREF="#3">getFile (String): IFile</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/14)</TD><TD CLASS="h">0%   (0/4)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#4">getFiles (Collection, IContainer, String): void</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/47)</TD><TD CLASS="h">0%   (0/9)</TD></TR><TR><TD CLASS="f"><A HREF="#5">getFiles (String): Collection</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/14)</TD><TD CLASS="h">0%   (0/4)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#6">getPortableName (IResource): String</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/4)</TD><TD CLASS="h">0%   (0/1)</TD></TR><TR><TD CLASS="f"><A HREF="#7">getTargetObjectName (Object): String</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/7)</TD><TD CLASS="h">0%   (0/3)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#8">getValidationFrameworkSeverity (int): int</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/10)</TD><TD CLASS="h">0%   (0/5)</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="#9">Helper$1</A></TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/2)</TD><TD CLASS="h">0%   (0/60)</TD><TD CLASS="h">0%   (0/12)</TD></TR><TR><TD CLASS="f"><A HREF="#9">Helper$1 (IMarker [], IMarker [], String, Object): void</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="#b">run (IProgressMonitor): void</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/45)</TD><TD CLASS="h">0%   (0/10)</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, 2005 IBM Corporation and others.</TD></TR><TR><TD CLASS="l">3</TD><TD> * All rights reserved. This program and the accompanying materials</TD></TR><TR><TD CLASS="l">4</TD><TD> * are made available under the terms of the Eclipse Public License v1.0</TD></TR><TR><TD CLASS="l">5</TD><TD> * which accompanies this distribution, and is available at</TD></TR><TR><TD CLASS="l">6</TD><TD> * http://www.eclipse.org/legal/epl-v10.html</TD></TR><TR><TD CLASS="l">7</TD><TD> * </TD></TR><TR><TD CLASS="l">8</TD><TD> * Contributors:</TD></TR><TR><TD CLASS="l">9</TD><TD> *     IBM Corporation - initial API and implementation</TD></TR><TR><TD CLASS="l">10</TD><TD> *******************************************************************************/</TD></TR><TR><TD CLASS="l">11</TD><TD> </TD></TR><TR><TD CLASS="l">12</TD><TD>package org.eclipse.wst.xml.core.internal.validation.core;</TD></TR><TR><TD CLASS="l">13</TD><TD> </TD></TR><TR><TD CLASS="l">14</TD><TD>import java.util.ArrayList;</TD></TR><TR><TD CLASS="l">15</TD><TD>import java.util.Collection;</TD></TR><TR><TD CLASS="l">16</TD><TD>import java.util.List;</TD></TR><TR><TD CLASS="l">17</TD><TD> </TD></TR><TR><TD CLASS="l">18</TD><TD>import org.eclipse.core.resources.IContainer;</TD></TR><TR><TD CLASS="l">19</TD><TD>import org.eclipse.core.resources.IFile;</TD></TR><TR><TD CLASS="l">20</TD><TD>import org.eclipse.core.resources.IMarker;</TD></TR><TR><TD CLASS="l">21</TD><TD>import org.eclipse.core.resources.IProject;</TD></TR><TR><TD CLASS="l">22</TD><TD>import org.eclipse.core.resources.IResource;</TD></TR><TR><TD CLASS="l">23</TD><TD>import org.eclipse.core.resources.IWorkspaceRunnable;</TD></TR><TR><TD CLASS="l">24</TD><TD>import org.eclipse.core.resources.ResourcesPlugin;</TD></TR><TR><TD CLASS="l">25</TD><TD>import org.eclipse.core.runtime.CoreException;</TD></TR><TR><TD CLASS="l">26</TD><TD>import org.eclipse.core.runtime.IProgressMonitor;</TD></TR><TR><TD CLASS="l">27</TD><TD>import org.eclipse.wst.validation.internal.operations.ValidatorManager;</TD></TR><TR><TD CLASS="l">28</TD><TD>import org.eclipse.wst.validation.internal.operations.WorkbenchContext;</TD></TR><TR><TD CLASS="l">29</TD><TD>import org.eclipse.wst.validation.internal.provisional.core.IMessage;</TD></TR><TR><TD CLASS="l">30</TD><TD> </TD></TR><TR><TD CLASS="l">31</TD><TD> </TD></TR><TR><TD CLASS="l">32</TD><TD>/**</TD></TR><TR><TD CLASS="l">33</TD><TD> * A helper class for validation in the validation framework.</TD></TR><TR><TD CLASS="l">34</TD><TD> * </TD></TR><TR><TD CLASS="l">35</TD><TD> * @author Ernest Mah (ernest@ca.ibm.com)</TD></TR><TR><TD CLASS="l">36</TD><TD> * @author Lawrence Mandel, IBM</TD></TR><TR><TD CLASS="l">37</TD><TD> */</TD></TR><TR><TD CLASS="l">38</TD><TD>public class Helper extends WorkbenchContext</TD></TR><TR><TD CLASS="l">39</TD><TD>{</TD></TR><TR><TD CLASS="l">40</TD><TD>  public static final String GET_PROJECT_FILES = &#34;getAllFiles&#34;; //$NON-NLS-1$</TD></TR><TR><TD CLASS="l">41</TD><TD>  public static final String GET_FILE = &#34;getFile&#34;; //$NON-NLS-1$</TD></TR><TR><TD CLASS="l">42</TD><TD>  //dw private static final IContainer[] NO_CONTAINERS = new IContainer[0];</TD></TR><TR><TD CLASS="l">43</TD><TD>  public static final String VALIDATION_MARKER = &#34;org.eclipse.wst.validation.problemmarker&#34;; //$NON-NLS-1$</TD></TR><TR><TD CLASS="l">44</TD><TD>  public static final String VALIDATION_MARKER_OWNER = &#34;owner&#34;;   //$NON-NLS-1$</TD></TR><TR><TD CLASS="l">45</TD><TD> </TD></TR><TR><TD CLASS="l">46</TD><TD>  /**</TD></TR><TR><TD CLASS="l"><A NAME="0">47</A></TD><TD>   * Constructor.</TD></TR><TR><TD CLASS="l">48</TD><TD>   */</TD></TR><TR><TD CLASS="l">49</TD><TD>  public Helper()</TD></TR><TR><TD CLASS="l">50</TD><TD>  {</TD></TR><TR CLASS="z"><TD CLASS="l">51</TD><TD>    super();</TD></TR><TR><TD CLASS="l">52</TD><TD> </TD></TR><TR><TD CLASS="l">53</TD><TD>    // the following will register the helper's symbolic methods</TD></TR><TR CLASS="z"><TD CLASS="l">54</TD><TD>    Class [] args = new Class[1] ;</TD></TR><TR CLASS="z"><TD CLASS="l">55</TD><TD>    args[0] = String.class ;  // a string argument denoting a specific JSP.</TD></TR><TR><TD CLASS="l">56</TD><TD>    </TD></TR><TR CLASS="z"><TD CLASS="l">57</TD><TD>    registerModel(GET_FILE, &#34;getFile&#34;, args);//$NON-NLS-1$</TD></TR><TR CLASS="z"><TD CLASS="l">58</TD><TD>    registerModel(GET_PROJECT_FILES, &#34;getFiles&#34;, args);//$NON-NLS-1$</TD></TR><TR CLASS="z"><TD CLASS="l">59</TD><TD>  }</TD></TR><TR><TD CLASS="l">60</TD><TD> </TD></TR><TR><TD CLASS="l">61</TD><TD>  /**</TD></TR><TR><TD CLASS="l">62</TD><TD>   * Get the IFile for the given filename.</TD></TR><TR><TD CLASS="l">63</TD><TD>   * </TD></TR><TR><TD CLASS="l">64</TD><TD>   * @param filename The name of the file to retrieve.</TD></TR><TR><TD CLASS="l">65</TD><TD>   * @return An IFile representing the file specified or null if it can't be resolved.</TD></TR><TR><TD CLASS="l"><A NAME="3">66</A></TD><TD>   */</TD></TR><TR><TD CLASS="l">67</TD><TD>  public IFile getFile(String filename)</TD></TR><TR><TD CLASS="l">68</TD><TD>  {</TD></TR><TR><TD CLASS="l">69</TD><TD>    //    System.out.println(&#34;file name = &#34; + filename);</TD></TR><TR CLASS="z"><TD CLASS="l">70</TD><TD>    IResource res = getProject().findMember(filename, true); // true means include phantom resources</TD></TR><TR CLASS="z"><TD CLASS="l">71</TD><TD>    if (res instanceof IFile) </TD></TR><TR><TD CLASS="l">72</TD><TD>    {</TD></TR><TR CLASS="z"><TD CLASS="l">73</TD><TD>      return (IFile) res;</TD></TR><TR><TD CLASS="l">74</TD><TD>    }</TD></TR><TR CLASS="z"><TD CLASS="l">75</TD><TD>    return null;</TD></TR><TR><TD CLASS="l">76</TD><TD>  }</TD></TR><TR><TD CLASS="l">77</TD><TD>  </TD></TR><TR><TD CLASS="l">78</TD><TD>  /**</TD></TR><TR><TD CLASS="l">79</TD><TD>   * Get the collection of files from the project that are relevant for the</TD></TR><TR><TD CLASS="l">80</TD><TD>   * validator with the given class name.</TD></TR><TR><TD CLASS="l">81</TD><TD>   * </TD></TR><TR><TD CLASS="l">82</TD><TD>   * @param validatorClassName The name of the validator class.</TD></TR><TR><TD CLASS="l"><A NAME="5">83</A></TD><TD>   * @return The collection of files relevant for the validator class specified.</TD></TR><TR><TD CLASS="l">84</TD><TD>   */</TD></TR><TR><TD CLASS="l">85</TD><TD>  public Collection getFiles(String validatorClassName)</TD></TR><TR><TD CLASS="l">86</TD><TD>  {</TD></TR><TR CLASS="z"><TD CLASS="l">87</TD><TD>    IProject project = getProject();</TD></TR><TR CLASS="z"><TD CLASS="l">88</TD><TD>    List files = new ArrayList();</TD></TR><TR CLASS="z"><TD CLASS="l">89</TD><TD>    getFiles(files, project, validatorClassName);</TD></TR><TR CLASS="z"><TD CLASS="l">90</TD><TD>    return files;</TD></TR><TR><TD CLASS="l">91</TD><TD>  }</TD></TR><TR><TD CLASS="l">92</TD><TD> </TD></TR><TR><TD CLASS="l">93</TD><TD>  /**</TD></TR><TR><TD CLASS="l">94</TD><TD>   * Get the collection of files from the project that are relevant for the</TD></TR><TR><TD CLASS="l">95</TD><TD>   * validator with the given class name.</TD></TR><TR><TD CLASS="l">96</TD><TD>   * </TD></TR><TR><TD CLASS="l">97</TD><TD>   * @param files The files relevant for the class name.</TD></TR><TR><TD CLASS="l">98</TD><TD>   * @param resource The resource to look for files in.</TD></TR><TR><TD CLASS="l">99</TD><TD>   * @param validatorClassName The name of the validator class.</TD></TR><TR><TD CLASS="l">100</TD><TD>   */</TD></TR><TR><TD CLASS="l"><A NAME="4">101</A></TD><TD>  protected void getFiles(Collection files, IContainer resource, String validatorClassName)</TD></TR><TR><TD CLASS="l">102</TD><TD>  {</TD></TR><TR><TD CLASS="l">103</TD><TD>    try</TD></TR><TR><TD CLASS="l">104</TD><TD>    {</TD></TR><TR CLASS="z"><TD CLASS="l">105</TD><TD>      IResource [] resourceArray = resource.members(false);</TD></TR><TR CLASS="z"><TD CLASS="l">106</TD><TD>      for (int i=0; i&lt;resourceArray.length; i++)</TD></TR><TR><TD CLASS="l">107</TD><TD>      {       </TD></TR><TR CLASS="z"><TD CLASS="l">108</TD><TD>        if (ValidatorManager.getManager().isApplicableTo(validatorClassName, resourceArray[i])) </TD></TR><TR><TD CLASS="l">109</TD><TD>        {</TD></TR><TR CLASS="z"><TD CLASS="l">110</TD><TD>          if (resourceArray[i] instanceof IFile) </TD></TR><TR><TD CLASS="l">111</TD><TD>          {</TD></TR><TR CLASS="z"><TD CLASS="l">112</TD><TD>            files.add(resourceArray[i]);</TD></TR><TR><TD CLASS="l">113</TD><TD>          }</TD></TR><TR><TD CLASS="l">114</TD><TD>        }</TD></TR><TR CLASS="z"><TD CLASS="l">115</TD><TD>        if (resourceArray[i].getType() == IResource.FOLDER)</TD></TR><TR CLASS="z"><TD CLASS="l">116</TD><TD>         getFiles(files,(IContainer)resourceArray[i], validatorClassName) ;</TD></TR><TR><TD CLASS="l">117</TD><TD>      }</TD></TR><TR><TD CLASS="l">118</TD><TD>    }</TD></TR><TR CLASS="z"><TD CLASS="l">119</TD><TD>    catch (Exception e) {}</TD></TR><TR CLASS="z"><TD CLASS="l">120</TD><TD>  }</TD></TR><TR><TD CLASS="l">121</TD><TD> </TD></TR><TR><TD CLASS="l">122</TD><TD>  </TD></TR><TR><TD CLASS="l">123</TD><TD>/**</TD></TR><TR><TD CLASS="l">124</TD><TD> * Return the name of the resource, without the project-specific information </TD></TR><TR><TD CLASS="l">125</TD><TD> * in front.</TD></TR><TR><TD CLASS="l">126</TD><TD> *</TD></TR><TR><TD CLASS="l">127</TD><TD> * This method is used by ValidationOperation to calculate the non-environment </TD></TR><TR><TD CLASS="l">128</TD><TD> * specific names of the files. Only the IWorkbenchContext implementation knows how </TD></TR><TR><TD CLASS="l">129</TD><TD> * much information to strip off of the IResource name. For example, if there is</TD></TR><TR><TD CLASS="l">130</TD><TD> * an EJB Project named &#34;MyEJBProject&#34;, and it uses the default names for the </TD></TR><TR><TD CLASS="l">131</TD><TD> * source and output folders, &#34;source&#34; and &#34;ejbModule&#34;, respectively, then the</TD></TR><TR><TD CLASS="l">132</TD><TD> * current implementation of EJB Helper knows how much of that structure is </TD></TR><TR><TD CLASS="l">133</TD><TD> * eclipse-specific. </TD></TR><TR><TD CLASS="l">134</TD><TD> *</TD></TR><TR><TD CLASS="l">135</TD><TD> * Since the &#34;source&#34; folder contains Java source files, a portable name would</TD></TR><TR><TD CLASS="l">136</TD><TD> * be the fully-qualified name of the Java class, without the eclipse-specific</TD></TR><TR><TD CLASS="l">137</TD><TD> * project and folder names in front of the file name. The EJBHelper knows that </TD></TR><TR><TD CLASS="l">138</TD><TD> * everything up to the &#34;source&#34; folder, for example, can be removed, because, </TD></TR><TR><TD CLASS="l">139</TD><TD> * according to the definition of the EJB Project, everything contained</TD></TR><TR><TD CLASS="l">140</TD><TD> * in the source folder is java source code. So if there is an IResource in an</TD></TR><TR><TD CLASS="l">141</TD><TD> * EJB Project named &#34;/MyEJBProject/source/com/ibm/myclasses/MyJavaFile.java&#34;,</TD></TR><TR><TD CLASS="l">142</TD><TD> * this method would make this name portable by stripping off the</TD></TR><TR><TD CLASS="l">143</TD><TD> * &#34;/MyEJBProject/source&#34;, and returning &#34;com/ibm/myclasses/MyJavaFile.java&#34;.</TD></TR><TR><TD CLASS="l">144</TD><TD> *</TD></TR><TR><TD CLASS="l">145</TD><TD> * The output of this method is used by the ValidationOperation, when it</TD></TR><TR><TD CLASS="l">146</TD><TD> * is calculating the list of added/changed/deleted file names for incremental</TD></TR><TR><TD CLASS="l">147</TD><TD> * validation. If getPortableName(IResource) returns null, that means</TD></TR><TR><TD CLASS="l">148</TD><TD> * that the IWorkbenchContext's implementation does not support that particular</TD></TR><TR><TD CLASS="l">149</TD><TD> * type of resource, and the resource should not be included in the array of</TD></TR><TR><TD CLASS="l">150</TD><TD> * IFileDelta objects in the IValidator's &#34;validate&#34; method. </TD></TR><TR><TD CLASS="l">151</TD><TD> * </TD></TR><TR><TD CLASS="l">152</TD><TD> * @param resource The resource to get the name from.</TD></TR><TR><TD CLASS="l">153</TD><TD> * @return The portable name of the resource.</TD></TR><TR><TD CLASS="l"><A NAME="6">154</A></TD><TD> */</TD></TR><TR><TD CLASS="l">155</TD><TD>public String getPortableName(IResource resource)</TD></TR><TR><TD CLASS="l">156</TD><TD>  {</TD></TR><TR><TD CLASS="l">157</TD><TD>    //    System.out.println(&#34;get portablename for &#34; + resource);</TD></TR><TR CLASS="z"><TD CLASS="l">158</TD><TD>    return resource.getProjectRelativePath().toString();</TD></TR><TR><TD CLASS="l">159</TD><TD>  }</TD></TR><TR><TD CLASS="l">160</TD><TD> </TD></TR><TR><TD CLASS="l">161</TD><TD>/**</TD></TR><TR><TD CLASS="l">162</TD><TD> * When an IValidator associates a target object with an IMessage,</TD></TR><TR><TD CLASS="l">163</TD><TD> * the WorkbenchReporter eventually resolves that target object</TD></TR><TR><TD CLASS="l">164</TD><TD> * with an IResource. Sometimes more than one target object resolves</TD></TR><TR><TD CLASS="l">165</TD><TD> * to the same IResource (usually the IProject, which is the default</TD></TR><TR><TD CLASS="l">166</TD><TD> * IResource when an IFile cannot be found). This method is called,</TD></TR><TR><TD CLASS="l">167</TD><TD> * by the WorkbenchReporter, so that the WorkbenchReporter can </TD></TR><TR><TD CLASS="l">168</TD><TD> * distinguish between the IMessages which are on the same IResource, </TD></TR><TR><TD CLASS="l">169</TD><TD> * but refer to different target objects. This is needed for the </TD></TR><TR><TD CLASS="l">170</TD><TD> * removeAllMessages(IValidator, Object) method, so that when one</TD></TR><TR><TD CLASS="l">171</TD><TD> * target object removes all of its messages, that it doesn't remove</TD></TR><TR><TD CLASS="l">172</TD><TD> * another target object's messages.</TD></TR><TR><TD CLASS="l">173</TD><TD> *</TD></TR><TR><TD CLASS="l">174</TD><TD> * This method may return null only if object is null. Otherwise, an</TD></TR><TR><TD CLASS="l">175</TD><TD> * id which can uniquely identify a particular object must be returned.</TD></TR><TR><TD CLASS="l">176</TD><TD> * The id needs to be unique only within one particular IValidator.</TD></TR><TR><TD CLASS="l">177</TD><TD> * </TD></TR><TR><TD CLASS="l">178</TD><TD> * @param object The object from which to get the name.</TD></TR><TR><TD CLASS="l"><A NAME="7">179</A></TD><TD> * @return The name of the object or null if the object is null.</TD></TR><TR><TD CLASS="l">180</TD><TD> */</TD></TR><TR><TD CLASS="l">181</TD><TD>public String getTargetObjectName(Object object)</TD></TR><TR><TD CLASS="l">182</TD><TD>  {</TD></TR><TR CLASS="z"><TD CLASS="l">183</TD><TD>    if (object == null) </TD></TR><TR><TD CLASS="l">184</TD><TD>    {</TD></TR><TR CLASS="z"><TD CLASS="l">185</TD><TD>      return null;</TD></TR><TR><TD CLASS="l">186</TD><TD>    }</TD></TR><TR><TD CLASS="l">187</TD><TD>    </TD></TR><TR><TD CLASS="l">188</TD><TD>    //    System.out.println(&#34;get targetname for &#34; + object);</TD></TR><TR CLASS="z"><TD CLASS="l">189</TD><TD>    return object.toString();</TD></TR><TR><TD CLASS="l">190</TD><TD>  }</TD></TR><TR><TD CLASS="l">191</TD><TD>  </TD></TR><TR><TD CLASS="l">192</TD><TD>  /**</TD></TR><TR><TD CLASS="l">193</TD><TD>   * Delete the markers of the specified type from the specified resource.</TD></TR><TR><TD CLASS="l">194</TD><TD>   * </TD></TR><TR><TD CLASS="l">195</TD><TD>   * @param resource The resource to delete the markers from.</TD></TR><TR><TD CLASS="l">196</TD><TD>   * @param markerType The type of markers to delete from the resource.</TD></TR><TR><TD CLASS="l">197</TD><TD>   * @param attributeName The name of the attribute which the markers must have to be deleted.</TD></TR><TR><TD CLASS="l">198</TD><TD>   * @param attributeValue The value of the attribute corresponding to attributeName which the markers must have to be deleted.</TD></TR><TR><TD CLASS="l"><A NAME="2">199</A></TD><TD>   * @throws CoreException</TD></TR><TR><TD CLASS="l">200</TD><TD>   */</TD></TR><TR><TD CLASS="l"><A NAME="9">201</A></TD><TD>  public static void deleteMarkers(IResource resource, String markerType, final String attributeName, final Object attributeValue) throws CoreException</TD></TR><TR><TD CLASS="l">202</TD><TD>  {          </TD></TR><TR CLASS="z"><TD CLASS="l">203</TD><TD>    final IMarker[] v400Markers = resource.findMarkers(IMarker.PROBLEM, false, IResource.DEPTH_INFINITE);</TD></TR><TR CLASS="z"><TD CLASS="l">204</TD><TD>    final IMarker[] markers = resource.findMarkers(markerType, true, IResource.DEPTH_INFINITE);</TD></TR><TR CLASS="z"><TD CLASS="l">205</TD><TD>    IWorkspaceRunnable op = new IWorkspaceRunnable() </TD></TR><TR><TD CLASS="l">206</TD><TD>     {</TD></TR><TR><TD CLASS="l">207</TD><TD>       public void run(IProgressMonitor progressMonitor) throws CoreException </TD></TR><TR><TD CLASS="l">208</TD><TD>       {    </TD></TR><TR><TD CLASS="l"><A NAME="b">209</A></TD><TD>         // this fixes defect 193406</TD></TR><TR><TD CLASS="l">210</TD><TD>         // here we remove markers that may have been added by the v400 code</TD></TR><TR><TD CLASS="l">211</TD><TD>         // hopefully the '.markers' metadata files will be removed for the V5 install</TD></TR><TR><TD CLASS="l">212</TD><TD>         // and this kludge will not be needed there</TD></TR><TR CLASS="z"><TD CLASS="l">213</TD><TD>         for (int i = 0; i &lt; v400Markers.length; i++)</TD></TR><TR><TD CLASS="l">214</TD><TD>         {</TD></TR><TR CLASS="z"><TD CLASS="l">215</TD><TD>           IMarker marker = markers[i];           </TD></TR><TR CLASS="z"><TD CLASS="l">216</TD><TD>           marker.delete();           </TD></TR><TR><TD CLASS="l">217</TD><TD>         }</TD></TR><TR><TD CLASS="l">218</TD><TD>    </TD></TR><TR CLASS="z"><TD CLASS="l">219</TD><TD>         for (int i = 0; i &lt; markers.length; i++) </TD></TR><TR><TD CLASS="l">220</TD><TD>         {</TD></TR><TR CLASS="z"><TD CLASS="l">221</TD><TD>           IMarker marker = markers[i];</TD></TR><TR><TD CLASS="l">222</TD><TD>           </TD></TR><TR CLASS="z"><TD CLASS="l">223</TD><TD>           Object value = marker.getAttribute(attributeName);</TD></TR><TR CLASS="z"><TD CLASS="l">224</TD><TD>           if (value != null &amp;&amp;</TD></TR><TR CLASS="z"><TD CLASS="l">225</TD><TD>               value.equals(attributeValue)) </TD></TR><TR><TD CLASS="l">226</TD><TD>           {</TD></TR><TR CLASS="z"><TD CLASS="l">227</TD><TD>             marker.delete();</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>       }</TD></TR><TR><TD CLASS="l">231</TD><TD>     };</TD></TR><TR><TD CLASS="l">232</TD><TD>    </TD></TR><TR><TD CLASS="l">233</TD><TD>    try</TD></TR><TR><TD CLASS="l">234</TD><TD>    {</TD></TR><TR CLASS="z"><TD CLASS="l">235</TD><TD>      ResourcesPlugin.getWorkspace().run(op, null);</TD></TR><TR><TD CLASS="l">236</TD><TD>    }</TD></TR><TR CLASS="z"><TD CLASS="l">237</TD><TD>    catch (Exception e) { }</TD></TR><TR CLASS="z"><TD CLASS="l">238</TD><TD>  }</TD></TR><TR><TD CLASS="l">239</TD><TD>  </TD></TR><TR><TD CLASS="l">240</TD><TD>  /**</TD></TR><TR><TD CLASS="l">241</TD><TD>   * Get the validation framework severity for the given severity.</TD></TR><TR><TD CLASS="l">242</TD><TD>   * </TD></TR><TR><TD CLASS="l">243</TD><TD>   * @param severity The severity to convert to validation framework severity.</TD></TR><TR><TD CLASS="l"><A NAME="8">244</A></TD><TD>   * @return The validation framework severity for the given severity.</TD></TR><TR><TD CLASS="l">245</TD><TD>   */</TD></TR><TR><TD CLASS="l">246</TD><TD>  static public int getValidationFrameworkSeverity(int severity)</TD></TR><TR><TD CLASS="l">247</TD><TD>  {</TD></TR><TR CLASS="z"><TD CLASS="l">248</TD><TD>    switch (severity)</TD></TR><TR><TD CLASS="l">249</TD><TD>    {</TD></TR><TR><TD CLASS="l">250</TD><TD>      case IMarker.SEVERITY_ERROR:</TD></TR><TR CLASS="z"><TD CLASS="l">251</TD><TD>        return IMessage.HIGH_SEVERITY;</TD></TR><TR><TD CLASS="l">252</TD><TD>      case IMarker.SEVERITY_WARNING:</TD></TR><TR CLASS="z"><TD CLASS="l">253</TD><TD>        return IMessage.NORMAL_SEVERITY;</TD></TR><TR><TD CLASS="l">254</TD><TD>      case IMarker.SEVERITY_INFO:</TD></TR><TR CLASS="z"><TD CLASS="l">255</TD><TD>        return IMessage.LOW_SEVERITY;</TD></TR><TR><TD CLASS="l">256</TD><TD>    }</TD></TR><TR CLASS="z"><TD CLASS="l">257</TD><TD>    return IMessage.LOW_SEVERITY;  </TD></TR><TR><TD CLASS="l">258</TD><TD>  }</TD></TR><TR><TD CLASS="l">259</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="95.html">org.eclipse.wst.xml.core.internal.validation.core</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>