<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="27.html">org.eclipse.wst.xml.core.internal.provisional.format</A>]</TD></TR></TABLE><H2>COVERAGE SUMMARY FOR SOURCE FILE [<SPAN CLASS="in">ElementNodeFormatter.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>ElementNodeFormatter.java</TD><TD CLASS="h">0% (0/1)</TD><TD CLASS="h">0% (0/5)</TD><TD CLASS="h">0% (0/954)</TD><TD CLASS="h">0% (0/196)</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">ElementNodeFormatter</A></TD><TD CLASS="h">0% (0/1)</TD><TD CLASS="h">0% (0/5)</TD><TD CLASS="h">0% (0/954)</TD><TD CLASS="h">0% (0/196)</TD></TR><TR><TD CLASS="f"><A HREF="#0">ElementNodeFormatter (): void</A></TD><TD> </TD><TD CLASS="h">0% (0/1)</TD><TD CLASS="h">0% (0/3)</TD><TD CLASS="h">0% (0/1)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#2">formatEndTag (IDOMNode, IStructuredFormatContraints): void</A></TD><TD> </TD><TD CLASS="h">0% (0/1)</TD><TD CLASS="h">0% (0/179)</TD><TD CLASS="h">0% (0/30)</TD></TR><TR><TD CLASS="f"><A HREF="#3">formatNode (IDOMNode, IStructuredFormatContraints): void</A></TD><TD> </TD><TD CLASS="h">0% (0/1)</TD><TD CLASS="h">0% (0/71)</TD><TD CLASS="h">0% (0/20)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#4">formatStartTag (IDOMNode, IStructuredFormatContraints): void</A></TD><TD> </TD><TD CLASS="h">0% (0/1)</TD><TD CLASS="h">0% (0/634)</TD><TD CLASS="h">0% (0/133)</TD></TR><TR><TD CLASS="f"><A HREF="#5">getUndefinedRegions (IDOMNode, int, int): String</A></TD><TD> </TD><TD CLASS="h">0% (0/1)</TD><TD CLASS="h">0% (0/67)</TD><TD CLASS="h">0% (0/12)</TD></TR></TABLE><P></P><TABLE CLASS="s" CELLSPACING="0" WIDTH="100%"><TR><TD CLASS="l">1</TD><TD>/*******************************************************************************</TD></TR><TR><TD CLASS="l">2</TD><TD> * Copyright (c) 2001, 2007 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> * Jesper Steen M�ller - xml:space='preserve' support</TD></TR><TR><TD CLASS="l">12</TD><TD> * </TD></TR><TR><TD CLASS="l">13</TD><TD> *******************************************************************************/</TD></TR><TR><TD CLASS="l">14</TD><TD>package org.eclipse.wst.xml.core.internal.provisional.format;</TD></TR><TR><TD CLASS="l">15</TD><TD> </TD></TR><TR><TD CLASS="l">16</TD><TD>import org.eclipse.jface.text.BadLocationException;</TD></TR><TR><TD CLASS="l">17</TD><TD>import org.eclipse.wst.sse.core.internal.format.IStructuredFormatContraints;</TD></TR><TR><TD CLASS="l">18</TD><TD>import org.eclipse.wst.sse.core.internal.provisional.text.IStructuredDocument;</TD></TR><TR><TD CLASS="l">19</TD><TD>import org.eclipse.wst.sse.core.internal.provisional.text.IStructuredDocumentRegion;</TD></TR><TR><TD CLASS="l">20</TD><TD>import org.eclipse.wst.sse.core.internal.provisional.text.ITextRegion;</TD></TR><TR><TD CLASS="l">21</TD><TD>import org.eclipse.wst.sse.core.internal.provisional.text.ITextRegionList;</TD></TR><TR><TD CLASS="l">22</TD><TD>import org.eclipse.wst.sse.core.utils.StringUtils;</TD></TR><TR><TD CLASS="l">23</TD><TD>import org.eclipse.wst.xml.core.internal.Logger;</TD></TR><TR><TD CLASS="l">24</TD><TD>import org.eclipse.wst.xml.core.internal.contentmodel.CMAttributeDeclaration;</TD></TR><TR><TD CLASS="l">25</TD><TD>import org.eclipse.wst.xml.core.internal.contentmodel.CMElementDeclaration;</TD></TR><TR><TD CLASS="l">26</TD><TD>import org.eclipse.wst.xml.core.internal.contentmodel.CMNamedNodeMap;</TD></TR><TR><TD CLASS="l">27</TD><TD>import org.eclipse.wst.xml.core.internal.document.AttrImpl;</TD></TR><TR><TD CLASS="l">28</TD><TD>import org.eclipse.wst.xml.core.internal.provisional.document.IDOMDocument;</TD></TR><TR><TD CLASS="l">29</TD><TD>import org.eclipse.wst.xml.core.internal.provisional.document.IDOMModel;</TD></TR><TR><TD CLASS="l">30</TD><TD>import org.eclipse.wst.xml.core.internal.provisional.document.IDOMNode;</TD></TR><TR><TD CLASS="l">31</TD><TD>import org.eclipse.wst.xml.core.internal.provisional.document.ISourceGenerator;</TD></TR><TR><TD CLASS="l">32</TD><TD>import org.eclipse.wst.xml.core.internal.regions.DOMRegionContext;</TD></TR><TR><TD CLASS="l">33</TD><TD>import org.eclipse.wst.xml.core.internal.ssemodelquery.ModelQueryAdapter;</TD></TR><TR><TD CLASS="l">34</TD><TD>import org.w3c.dom.Element;</TD></TR><TR><TD CLASS="l"><A NAME="0">35</A></TD><TD>import org.w3c.dom.NamedNodeMap;</TD></TR><TR><TD CLASS="l">36</TD><TD>import org.w3c.dom.Node;</TD></TR><TR><TD CLASS="l">37</TD><TD> </TD></TR><TR><TD CLASS="l">38</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">39</TD><TD>public class ElementNodeFormatter extends DocumentNodeFormatter {</TD></TR><TR><TD CLASS="l">40</TD><TD> static private final char DOUBLE_QUOTE = '"';//$NON-NLS-1$</TD></TR><TR><TD CLASS="l">41</TD><TD> static private final String DOUBLE_QUOTES = "\"\"";//$NON-NLS-1$</TD></TR><TR><TD CLASS="l">42</TD><TD> static private final char EQUAL_CHAR = '='; // equal sign$NON-NLS-1$</TD></TR><TR><TD CLASS="l">43</TD><TD> static private final String PRESERVE = "preserve";//$NON-NLS-1$</TD></TR><TR><TD CLASS="l">44</TD><TD> static private final String PRESERVE_QUOTED = "\"preserve\"";//$NON-NLS-1$</TD></TR><TR><TD CLASS="l">45</TD><TD> static private final char SINGLE_QUOTE = '\'';//$NON-NLS-1$</TD></TR><TR><TD CLASS="l">46</TD><TD> static private final String XML_SPACE = "xml:space";//$NON-NLS-1$</TD></TR><TR><TD CLASS="l">47</TD><TD> static private final char SPACE_CHAR = ' '; //$NON-NLS-1$</TD></TR><TR><TD CLASS="l">48</TD><TD> static private final String XSL_NAMESPACE = "http://www.w3.org/1999/XSL/Transform"; //$NON-NLS-1$</TD></TR><TR><TD CLASS="l"><A NAME="2">49</A></TD><TD> static private final String XSL_ATTRIBUTE = "attribute"; //$NON-NLS-1$</TD></TR><TR><TD CLASS="l">50</TD><TD> static private final String XSL_TEXT = "text"; //$NON-NLS-1$</TD></TR><TR><TD CLASS="l">51</TD><TD> </TD></TR><TR><TD CLASS="l">52</TD><TD> protected void formatEndTag(IDOMNode node, IStructuredFormatContraints formatContraints) {</TD></TR><TR CLASS="z"><TD CLASS="l">53</TD><TD> if (!isEndTagMissing(node)) {</TD></TR><TR><TD CLASS="l">54</TD><TD> // end tag exists</TD></TR><TR><TD CLASS="l">55</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">56</TD><TD> IStructuredDocument structuredDocument = node.getModel().getStructuredDocument();</TD></TR><TR CLASS="z"><TD CLASS="l">57</TD><TD> String lineDelimiter = structuredDocument.getLineDelimiter();</TD></TR><TR CLASS="z"><TD CLASS="l">58</TD><TD> String nodeIndentation = getNodeIndent(node);</TD></TR><TR CLASS="z"><TD CLASS="l">59</TD><TD> IDOMNode lastChild = (IDOMNode) node.getLastChild();</TD></TR><TR CLASS="z"><TD CLASS="l">60</TD><TD> if (lastChild != null && lastChild.getNodeType() != Node.TEXT_NODE) {</TD></TR><TR CLASS="z"><TD CLASS="l">61</TD><TD> if (isEndTagMissing(lastChild)) {</TD></TR><TR><TD CLASS="l">62</TD><TD> // find deepest child</TD></TR><TR CLASS="z"><TD CLASS="l">63</TD><TD> IDOMNode deepestChild = (IDOMNode) lastChild.getLastChild();</TD></TR><TR CLASS="z"><TD CLASS="l">64</TD><TD> while (deepestChild != null && deepestChild.getLastChild() != null && isEndTagMissing(deepestChild)) {</TD></TR><TR CLASS="z"><TD CLASS="l">65</TD><TD> lastChild = deepestChild;</TD></TR><TR CLASS="z"><TD CLASS="l">66</TD><TD> deepestChild = (IDOMNode) deepestChild.getLastChild();</TD></TR><TR><TD CLASS="l">67</TD><TD> }</TD></TR><TR><TD CLASS="l">68</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">69</TD><TD> if (deepestChild != null) {</TD></TR><TR CLASS="z"><TD CLASS="l">70</TD><TD> if (deepestChild.getNodeType() == Node.TEXT_NODE) {</TD></TR><TR><TD CLASS="l">71</TD><TD> // Special indentation handling if lastChild's end</TD></TR><TR><TD CLASS="l">72</TD><TD> // tag is missing and deepestChild is a text node.</TD></TR><TR CLASS="z"><TD CLASS="l">73</TD><TD> String nodeText = deepestChild.getNodeValue();</TD></TR><TR><TD CLASS="l">74</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">75</TD><TD> if (!nodeText.endsWith(lineDelimiter + nodeIndentation)) {</TD></TR><TR CLASS="z"><TD CLASS="l">76</TD><TD> nodeText = StringUtils.appendIfNotEndWith(nodeText, lineDelimiter);</TD></TR><TR CLASS="z"><TD CLASS="l">77</TD><TD> nodeText = StringUtils.appendIfNotEndWith(nodeText, nodeIndentation);</TD></TR><TR><TD CLASS="l">78</TD><TD> }</TD></TR><TR><TD CLASS="l">79</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">80</TD><TD> replaceNodeValue(deepestChild, nodeText);</TD></TR><TR><TD CLASS="l">81</TD><TD> }</TD></TR><TR><TD CLASS="l">82</TD><TD> else</TD></TR><TR CLASS="z"><TD CLASS="l">83</TD><TD> insertAfterNode(lastChild, lineDelimiter + nodeIndentation);</TD></TR><TR><TD CLASS="l">84</TD><TD> }</TD></TR><TR><TD CLASS="l">85</TD><TD> }</TD></TR><TR><TD CLASS="l">86</TD><TD> else</TD></TR><TR><TD CLASS="l">87</TD><TD> // indent end tag</TD></TR><TR CLASS="z"><TD CLASS="l">88</TD><TD> insertAfterNode(lastChild, lineDelimiter + nodeIndentation);</TD></TR><TR><TD CLASS="l">89</TD><TD> }</TD></TR><TR CLASS="z"><TD CLASS="l">90</TD><TD> else if (lastChild == null && firstStructuredDocumentRegionContainsLineDelimiters(node)) {</TD></TR><TR><TD CLASS="l">91</TD><TD> // BUG174243 do not indent end tag if node has empty content</TD></TR><TR><TD CLASS="l">92</TD><TD> // (otherwise new text node would be introduced)</TD></TR><TR CLASS="z"><TD CLASS="l">93</TD><TD> ModelQueryAdapter adapter = (ModelQueryAdapter) ((IDOMDocument) node.getOwnerDocument()).getAdapterFor(ModelQueryAdapter.class);</TD></TR><TR CLASS="z"><TD CLASS="l">94</TD><TD> CMElementDeclaration elementDeclaration = (CMElementDeclaration) adapter.getModelQuery().getCMNode(node);</TD></TR><TR CLASS="z"><TD CLASS="l">95</TD><TD> if ((elementDeclaration == null) || (elementDeclaration.getContentType() != CMElementDeclaration.EMPTY)) {</TD></TR><TR><TD CLASS="l">96</TD><TD> // indent end tag</TD></TR><TR CLASS="z"><TD CLASS="l">97</TD><TD> replace(structuredDocument, node.getFirstStructuredDocumentRegion().getEndOffset(), 0, lineDelimiter + nodeIndentation);</TD></TR><TR><TD CLASS="l">98</TD><TD> }</TD></TR><TR><TD CLASS="l">99</TD><TD> }</TD></TR><TR><TD CLASS="l">100</TD><TD> </TD></TR><TR><TD CLASS="l">101</TD><TD> // format end tag name</TD></TR><TR CLASS="z"><TD CLASS="l">102</TD><TD> IStructuredDocumentRegion endTagStructuredDocumentRegion = node.getLastStructuredDocumentRegion();</TD></TR><TR CLASS="z"><TD CLASS="l">103</TD><TD> if (endTagStructuredDocumentRegion.getRegions().size() >= 3) {</TD></TR><TR CLASS="z"><TD CLASS="l">104</TD><TD> ITextRegion endTagNameRegion = endTagStructuredDocumentRegion.getRegions().get(1);</TD></TR><TR CLASS="z"><TD CLASS="l">105</TD><TD> removeRegionSpaces(node, endTagStructuredDocumentRegion, endTagNameRegion);</TD></TR><TR><TD CLASS="l">106</TD><TD> }</TD></TR><TR><TD CLASS="l"><A NAME="3">107</A></TD><TD> }</TD></TR><TR CLASS="z"><TD CLASS="l">108</TD><TD> }</TD></TR><TR><TD CLASS="l">109</TD><TD> </TD></TR><TR><TD CLASS="l">110</TD><TD> protected void formatNode(IDOMNode node, IStructuredFormatContraints formatContraints) {</TD></TR><TR CLASS="z"><TD CLASS="l">111</TD><TD> if (node != null) {</TD></TR><TR><TD CLASS="l">112</TD><TD> // format indentation before node</TD></TR><TR CLASS="z"><TD CLASS="l">113</TD><TD> formatIndentationBeforeNode(node, formatContraints);</TD></TR><TR><TD CLASS="l">114</TD><TD> </TD></TR><TR><TD CLASS="l">115</TD><TD> // format start tag</TD></TR><TR CLASS="z"><TD CLASS="l">116</TD><TD> IDOMNode newNode = node;</TD></TR><TR CLASS="z"><TD CLASS="l">117</TD><TD> int startTagStartOffset = node.getStartOffset();</TD></TR><TR CLASS="z"><TD CLASS="l">118</TD><TD> IDOMModel structuredModel = node.getModel();</TD></TR><TR><TD CLASS="l">119</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">120</TD><TD> boolean currentlyInXmlSpacePreserve = formatContraints.getInPreserveSpaceElement();</TD></TR><TR CLASS="z"><TD CLASS="l">121</TD><TD> formatStartTag(node, formatContraints);</TD></TR><TR><TD CLASS="l">122</TD><TD> // save new node</TD></TR><TR CLASS="z"><TD CLASS="l">123</TD><TD> newNode = (IDOMNode) structuredModel.getIndexedRegion(startTagStartOffset);</TD></TR><TR><TD CLASS="l">124</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">125</TD><TD> IStructuredDocumentRegion flatNode = newNode.getFirstStructuredDocumentRegion();</TD></TR><TR CLASS="z"><TD CLASS="l">126</TD><TD> if (flatNode != null) {</TD></TR><TR CLASS="z"><TD CLASS="l">127</TD><TD> ITextRegionList regions = flatNode.getRegions();</TD></TR><TR CLASS="z"><TD CLASS="l">128</TD><TD> ITextRegion lastRegion = regions.get(regions.size() - 1);</TD></TR><TR><TD CLASS="l">129</TD><TD> // format children and end tag if not empty start tag</TD></TR><TR CLASS="z"><TD CLASS="l">130</TD><TD> if (lastRegion.getType() != DOMRegionContext.XML_EMPTY_TAG_CLOSE) {</TD></TR><TR><TD CLASS="l">131</TD><TD> // format children</TD></TR><TR CLASS="z"><TD CLASS="l">132</TD><TD> formatChildren(newNode, formatContraints);</TD></TR><TR><TD CLASS="l">133</TD><TD> </TD></TR><TR><TD CLASS="l">134</TD><TD> // save new node</TD></TR><TR CLASS="z"><TD CLASS="l">135</TD><TD> newNode = (IDOMNode) structuredModel.getIndexedRegion(startTagStartOffset);</TD></TR><TR><TD CLASS="l">136</TD><TD> </TD></TR><TR><TD CLASS="l">137</TD><TD> // format end tag</TD></TR><TR CLASS="z"><TD CLASS="l">138</TD><TD> formatEndTag(newNode, formatContraints);</TD></TR><TR><TD CLASS="l">139</TD><TD> }</TD></TR><TR><TD CLASS="l">140</TD><TD> }</TD></TR><TR><TD CLASS="l">141</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">142</TD><TD> formatContraints.setInPreserveSpaceElement(currentlyInXmlSpacePreserve);</TD></TR><TR><TD CLASS="l">143</TD><TD> // only indent if not at last node</TD></TR><TR CLASS="z"><TD CLASS="l">144</TD><TD> if (newNode != null && newNode.getNextSibling() != null)</TD></TR><TR><TD CLASS="l">145</TD><TD> // format indentation after node</TD></TR><TR CLASS="z"><TD CLASS="l">146</TD><TD> formatIndentationAfterNode(newNode, formatContraints);</TD></TR><TR><TD CLASS="l">147</TD><TD> }</TD></TR><TR CLASS="z"><TD CLASS="l">148</TD><TD> }</TD></TR><TR><TD CLASS="l">149</TD><TD> </TD></TR><TR><TD CLASS="l">150</TD><TD> /**</TD></TR><TR><TD CLASS="l"><A NAME="4">151</A></TD><TD> * This method formats the start tag name, and formats the attributes if</TD></TR><TR><TD CLASS="l">152</TD><TD> * available.</TD></TR><TR><TD CLASS="l">153</TD><TD> */</TD></TR><TR><TD CLASS="l">154</TD><TD> protected void formatStartTag(IDOMNode node, IStructuredFormatContraints formatContraints) {</TD></TR><TR CLASS="z"><TD CLASS="l">155</TD><TD> StructuredFormatPreferencesXML preferences = (StructuredFormatPreferencesXML) getFormatPreferences();</TD></TR><TR CLASS="z"><TD CLASS="l">156</TD><TD> String singleIndent = preferences.getIndent();</TD></TR><TR CLASS="z"><TD CLASS="l">157</TD><TD> String lineIndent = formatContraints.getCurrentIndent();</TD></TR><TR CLASS="z"><TD CLASS="l">158</TD><TD> String attrIndent = lineIndent + singleIndent;</TD></TR><TR CLASS="z"><TD CLASS="l">159</TD><TD> boolean splitMultiAttrs = preferences.getSplitMultiAttrs();</TD></TR><TR CLASS="z"><TD CLASS="l">160</TD><TD> boolean alignEndBracket = preferences.isAlignEndBracket();</TD></TR><TR CLASS="z"><TD CLASS="l">161</TD><TD> boolean sawXmlSpace = false;</TD></TR><TR><TD CLASS="l">162</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">163</TD><TD> IStructuredDocumentRegion flatNode = node.getFirstStructuredDocumentRegion();</TD></TR><TR CLASS="z"><TD CLASS="l">164</TD><TD> NamedNodeMap attributes = node.getAttributes();</TD></TR><TR><TD CLASS="l">165</TD><TD> </TD></TR><TR><TD CLASS="l">166</TD><TD> // Note: attributes should not be null even if the node has no</TD></TR><TR><TD CLASS="l">167</TD><TD> // attributes. However, attributes.getLength() will be 0. But, check</TD></TR><TR><TD CLASS="l">168</TD><TD> // for null just in case.</TD></TR><TR CLASS="z"><TD CLASS="l">169</TD><TD> if (attributes != null) {</TD></TR><TR><TD CLASS="l">170</TD><TD> // compute current available line width</TD></TR><TR CLASS="z"><TD CLASS="l">171</TD><TD> int currentAvailableLineWidth = 0;</TD></TR><TR><TD CLASS="l">172</TD><TD> try {</TD></TR><TR><TD CLASS="l">173</TD><TD> // 1 is for "<"</TD></TR><TR CLASS="z"><TD CLASS="l">174</TD><TD> int nodeNameOffset = node.getStartOffset() + 1 + node.getNodeName().length();</TD></TR><TR CLASS="z"><TD CLASS="l">175</TD><TD> int lineOffset = node.getStructuredDocument().getLineInformationOfOffset(nodeNameOffset).getOffset();</TD></TR><TR CLASS="z"><TD CLASS="l">176</TD><TD> String text = node.getStructuredDocument().get(lineOffset, nodeNameOffset - lineOffset);</TD></TR><TR CLASS="z"><TD CLASS="l">177</TD><TD> int usedWidth = getIndentationLength(text);</TD></TR><TR CLASS="z"><TD CLASS="l">178</TD><TD> currentAvailableLineWidth = preferences.getLineWidth() - usedWidth;</TD></TR><TR><TD CLASS="l">179</TD><TD> }</TD></TR><TR CLASS="z"><TD CLASS="l">180</TD><TD> catch (BadLocationException e) {</TD></TR><TR><TD CLASS="l">181</TD><TD> // log for now, unless we find reason not to</TD></TR><TR CLASS="z"><TD CLASS="l">182</TD><TD> Logger.log(Logger.INFO, e.getMessage());</TD></TR><TR><TD CLASS="l">183</TD><TD> }</TD></TR><TR><TD CLASS="l">184</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">185</TD><TD> StringBuffer stringBuffer = new StringBuffer();</TD></TR><TR CLASS="z"><TD CLASS="l">186</TD><TD> String lineDelimiter = node.getModel().getStructuredDocument().getLineDelimiter();</TD></TR><TR CLASS="z"><TD CLASS="l">187</TD><TD> int attrLength = attributes.getLength();</TD></TR><TR CLASS="z"><TD CLASS="l">188</TD><TD> int lastUndefinedRegionOffset = 0;</TD></TR><TR CLASS="z"><TD CLASS="l">189</TD><TD> boolean startTagSpansOver1Line = false;</TD></TR><TR><TD CLASS="l">190</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">191</TD><TD> for (int i = 0; i < attrLength; i++) {</TD></TR><TR CLASS="z"><TD CLASS="l">192</TD><TD> AttrImpl attr = (AttrImpl) attributes.item(i);</TD></TR><TR CLASS="z"><TD CLASS="l">193</TD><TD> ITextRegion nameRegion = attr.getNameRegion();</TD></TR><TR CLASS="z"><TD CLASS="l">194</TD><TD> ITextRegion equalRegion = attr.getEqualRegion();</TD></TR><TR CLASS="z"><TD CLASS="l">195</TD><TD> ITextRegion valueRegion = attr.getValueRegion();</TD></TR><TR><TD CLASS="l">196</TD><TD> </TD></TR><TR><TD CLASS="l">197</TD><TD> // append undefined regions</TD></TR><TR CLASS="z"><TD CLASS="l">198</TD><TD> String undefinedRegion = getUndefinedRegions(node, lastUndefinedRegionOffset, attr.getStartOffset() - lastUndefinedRegionOffset);</TD></TR><TR CLASS="z"><TD CLASS="l">199</TD><TD> stringBuffer.append(undefinedRegion);</TD></TR><TR CLASS="z"><TD CLASS="l">200</TD><TD> lastUndefinedRegionOffset = attr.getStartOffset();</TD></TR><TR><TD CLASS="l">201</TD><TD> </TD></TR><TR><TD CLASS="l">202</TD><TD> // check for xml:space attribute</TD></TR><TR CLASS="z"><TD CLASS="l">203</TD><TD> if (flatNode.getText(nameRegion).compareTo(XML_SPACE) == 0) {</TD></TR><TR CLASS="z"><TD CLASS="l">204</TD><TD> if (valueRegion == null) {</TD></TR><TR><TD CLASS="l">205</TD><TD> // [111674] If nothing has been written yet, treat as</TD></TR><TR><TD CLASS="l">206</TD><TD> // preserve, but only as hint</TD></TR><TR CLASS="z"><TD CLASS="l">207</TD><TD> formatContraints.setInPreserveSpaceElement(true);</TD></TR><TR><TD CLASS="l">208</TD><TD> // Note we don't set 'sawXmlSpace', so that default or</TD></TR><TR><TD CLASS="l">209</TD><TD> // fixed DTD/XSD values may override.</TD></TR><TR><TD CLASS="l">210</TD><TD> }</TD></TR><TR><TD CLASS="l">211</TD><TD> else {</TD></TR><TR CLASS="z"><TD CLASS="l">212</TD><TD> ISourceGenerator generator = node.getModel().getGenerator();</TD></TR><TR CLASS="z"><TD CLASS="l">213</TD><TD> String newAttrValue = generator.generateAttrValue(attr);</TD></TR><TR><TD CLASS="l">214</TD><TD> </TD></TR><TR><TD CLASS="l">215</TD><TD> // There is a problem in</TD></TR><TR><TD CLASS="l">216</TD><TD> // StructuredDocumentRegionUtil.getAttrValue(ITextRegion)</TD></TR><TR><TD CLASS="l">217</TD><TD> // when the region is instanceof ContextRegion.</TD></TR><TR><TD CLASS="l">218</TD><TD> // Workaround for now.</TD></TR><TR CLASS="z"><TD CLASS="l">219</TD><TD> if (flatNode.getText(valueRegion).length() == 1) {</TD></TR><TR CLASS="z"><TD CLASS="l">220</TD><TD> char firstChar = flatNode.getText(valueRegion).charAt(0);</TD></TR><TR CLASS="z"><TD CLASS="l">221</TD><TD> if ((firstChar == DOUBLE_QUOTE) || (firstChar == SINGLE_QUOTE))</TD></TR><TR CLASS="z"><TD CLASS="l">222</TD><TD> newAttrValue = DOUBLE_QUOTES;</TD></TR><TR><TD CLASS="l">223</TD><TD> }</TD></TR><TR><TD CLASS="l">224</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">225</TD><TD> if (newAttrValue.compareTo(PRESERVE_QUOTED) == 0)</TD></TR><TR CLASS="z"><TD CLASS="l">226</TD><TD> formatContraints.setInPreserveSpaceElement(true);</TD></TR><TR><TD CLASS="l">227</TD><TD> else</TD></TR><TR CLASS="z"><TD CLASS="l">228</TD><TD> formatContraints.setInPreserveSpaceElement(false);</TD></TR><TR CLASS="z"><TD CLASS="l">229</TD><TD> sawXmlSpace = true;</TD></TR><TR><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 CLASS="z"><TD CLASS="l">233</TD><TD> if (splitMultiAttrs && attrLength > 1) {</TD></TR><TR CLASS="z"><TD CLASS="l">234</TD><TD> stringBuffer.append(lineDelimiter + attrIndent);</TD></TR><TR CLASS="z"><TD CLASS="l">235</TD><TD> stringBuffer.append(flatNode.getText(nameRegion));</TD></TR><TR CLASS="z"><TD CLASS="l">236</TD><TD> startTagSpansOver1Line = true;</TD></TR><TR CLASS="z"><TD CLASS="l">237</TD><TD> if (valueRegion != null) {</TD></TR><TR><TD CLASS="l">238</TD><TD> // append undefined regions</TD></TR><TR CLASS="z"><TD CLASS="l">239</TD><TD> undefinedRegion = getUndefinedRegions(node, lastUndefinedRegionOffset, flatNode.getStartOffset(equalRegion) - lastUndefinedRegionOffset);</TD></TR><TR CLASS="z"><TD CLASS="l">240</TD><TD> stringBuffer.append(undefinedRegion);</TD></TR><TR CLASS="z"><TD CLASS="l">241</TD><TD> lastUndefinedRegionOffset = flatNode.getStartOffset(equalRegion);</TD></TR><TR><TD CLASS="l">242</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">243</TD><TD> stringBuffer.append(EQUAL_CHAR);</TD></TR><TR><TD CLASS="l">244</TD><TD> </TD></TR><TR><TD CLASS="l">245</TD><TD> // append undefined regions</TD></TR><TR CLASS="z"><TD CLASS="l">246</TD><TD> undefinedRegion = getUndefinedRegions(node, lastUndefinedRegionOffset, flatNode.getStartOffset(valueRegion) - lastUndefinedRegionOffset);</TD></TR><TR CLASS="z"><TD CLASS="l">247</TD><TD> stringBuffer.append(undefinedRegion);</TD></TR><TR CLASS="z"><TD CLASS="l">248</TD><TD> lastUndefinedRegionOffset = flatNode.getStartOffset(valueRegion);</TD></TR><TR><TD CLASS="l">249</TD><TD> </TD></TR><TR><TD CLASS="l">250</TD><TD> // Note: trim() should not be needed for</TD></TR><TR><TD CLASS="l">251</TD><TD> // valueRegion.getText(). Just a workaround for a</TD></TR><TR><TD CLASS="l">252</TD><TD> // problem found in valueRegion for now.</TD></TR><TR CLASS="z"><TD CLASS="l">253</TD><TD> stringBuffer.append(flatNode.getText(valueRegion).trim());</TD></TR><TR><TD CLASS="l">254</TD><TD> }</TD></TR><TR><TD CLASS="l">255</TD><TD> }</TD></TR><TR><TD CLASS="l">256</TD><TD> else {</TD></TR><TR CLASS="z"><TD CLASS="l">257</TD><TD> if (valueRegion != null) {</TD></TR><TR CLASS="z"><TD CLASS="l">258</TD><TD> int textLength = 1 + flatNode.getText(nameRegion).length() + 1 + flatNode.getText(valueRegion).length();</TD></TR><TR CLASS="z"><TD CLASS="l">259</TD><TD> if (i == attrLength - 1) {</TD></TR><TR CLASS="z"><TD CLASS="l">260</TD><TD> if (flatNode != null) {</TD></TR><TR CLASS="z"><TD CLASS="l">261</TD><TD> ITextRegionList regions = flatNode.getRegions();</TD></TR><TR CLASS="z"><TD CLASS="l">262</TD><TD> ITextRegion lastRegion = regions.get(regions.size() - 1);</TD></TR><TR CLASS="z"><TD CLASS="l">263</TD><TD> if (lastRegion.getType() != DOMRegionContext.XML_EMPTY_TAG_CLOSE)</TD></TR><TR><TD CLASS="l">264</TD><TD> // 3 is for " />"</TD></TR><TR CLASS="z"><TD CLASS="l">265</TD><TD> textLength += 3;</TD></TR><TR><TD CLASS="l">266</TD><TD> else</TD></TR><TR><TD CLASS="l">267</TD><TD> // 1 is for ">"</TD></TR><TR CLASS="z"><TD CLASS="l">268</TD><TD> textLength++;</TD></TR><TR><TD CLASS="l">269</TD><TD> }</TD></TR><TR><TD CLASS="l">270</TD><TD> }</TD></TR><TR><TD CLASS="l">271</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">272</TD><TD> if (currentAvailableLineWidth >= textLength) {</TD></TR><TR CLASS="z"><TD CLASS="l">273</TD><TD> stringBuffer.append(SPACE_CHAR);</TD></TR><TR CLASS="z"><TD CLASS="l">274</TD><TD> currentAvailableLineWidth--;</TD></TR><TR><TD CLASS="l">275</TD><TD> }</TD></TR><TR><TD CLASS="l">276</TD><TD> else {</TD></TR><TR CLASS="z"><TD CLASS="l">277</TD><TD> stringBuffer.append(lineDelimiter + attrIndent);</TD></TR><TR CLASS="z"><TD CLASS="l">278</TD><TD> startTagSpansOver1Line = true;</TD></TR><TR CLASS="z"><TD CLASS="l">279</TD><TD> currentAvailableLineWidth = preferences.getLineWidth() - attrIndent.length();</TD></TR><TR><TD CLASS="l">280</TD><TD> }</TD></TR><TR><TD CLASS="l">281</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">282</TD><TD> stringBuffer.append(flatNode.getText(nameRegion));</TD></TR><TR><TD CLASS="l">283</TD><TD> </TD></TR><TR><TD CLASS="l">284</TD><TD> // append undefined regions</TD></TR><TR CLASS="z"><TD CLASS="l">285</TD><TD> undefinedRegion = getUndefinedRegions(node, lastUndefinedRegionOffset, flatNode.getStartOffset(equalRegion) - lastUndefinedRegionOffset);</TD></TR><TR CLASS="z"><TD CLASS="l">286</TD><TD> stringBuffer.append(undefinedRegion);</TD></TR><TR CLASS="z"><TD CLASS="l">287</TD><TD> lastUndefinedRegionOffset = flatNode.getStartOffset(equalRegion);</TD></TR><TR><TD CLASS="l">288</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">289</TD><TD> stringBuffer.append(EQUAL_CHAR);</TD></TR><TR><TD CLASS="l">290</TD><TD> </TD></TR><TR><TD CLASS="l">291</TD><TD> // append undefined regions</TD></TR><TR CLASS="z"><TD CLASS="l">292</TD><TD> undefinedRegion = getUndefinedRegions(node, lastUndefinedRegionOffset, flatNode.getStartOffset(valueRegion) - lastUndefinedRegionOffset);</TD></TR><TR CLASS="z"><TD CLASS="l">293</TD><TD> stringBuffer.append(undefinedRegion);</TD></TR><TR CLASS="z"><TD CLASS="l">294</TD><TD> lastUndefinedRegionOffset = flatNode.getStartOffset(valueRegion);</TD></TR><TR><TD CLASS="l">295</TD><TD> </TD></TR><TR><TD CLASS="l">296</TD><TD> // Note: trim() should not be needed for</TD></TR><TR><TD CLASS="l">297</TD><TD> // valueRegion.getText(). Just a workaround for a</TD></TR><TR><TD CLASS="l">298</TD><TD> // problem found in valueRegion for now.</TD></TR><TR CLASS="z"><TD CLASS="l">299</TD><TD> stringBuffer.append(flatNode.getText(valueRegion).trim());</TD></TR><TR><TD CLASS="l">300</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">301</TD><TD> currentAvailableLineWidth -= flatNode.getText(nameRegion).length();</TD></TR><TR CLASS="z"><TD CLASS="l">302</TD><TD> currentAvailableLineWidth--;</TD></TR><TR CLASS="z"><TD CLASS="l">303</TD><TD> currentAvailableLineWidth -= flatNode.getText(valueRegion).trim().length();</TD></TR><TR><TD CLASS="l">304</TD><TD> }</TD></TR><TR><TD CLASS="l">305</TD><TD> else {</TD></TR><TR CLASS="z"><TD CLASS="l">306</TD><TD> if (currentAvailableLineWidth >= 1 + flatNode.getText(nameRegion).length()) {</TD></TR><TR CLASS="z"><TD CLASS="l">307</TD><TD> stringBuffer.append(SPACE_CHAR);</TD></TR><TR CLASS="z"><TD CLASS="l">308</TD><TD> currentAvailableLineWidth--;</TD></TR><TR><TD CLASS="l">309</TD><TD> }</TD></TR><TR><TD CLASS="l">310</TD><TD> else {</TD></TR><TR CLASS="z"><TD CLASS="l">311</TD><TD> stringBuffer.append(lineDelimiter + attrIndent);</TD></TR><TR CLASS="z"><TD CLASS="l">312</TD><TD> startTagSpansOver1Line = true;</TD></TR><TR CLASS="z"><TD CLASS="l">313</TD><TD> currentAvailableLineWidth = preferences.getLineWidth() - attrIndent.length();</TD></TR><TR><TD CLASS="l">314</TD><TD> }</TD></TR><TR><TD CLASS="l">315</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">316</TD><TD> stringBuffer.append(flatNode.getText(nameRegion));</TD></TR><TR><TD CLASS="l">317</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">318</TD><TD> currentAvailableLineWidth -= flatNode.getText(nameRegion).length();</TD></TR><TR><TD CLASS="l">319</TD><TD> }</TD></TR><TR><TD CLASS="l">320</TD><TD> }</TD></TR><TR><TD CLASS="l">321</TD><TD> }</TD></TR><TR><TD CLASS="l">322</TD><TD> </TD></TR><TR><TD CLASS="l">323</TD><TD> // append undefined regions</TD></TR><TR CLASS="z"><TD CLASS="l">324</TD><TD> String undefinedRegion = getUndefinedRegions(node, lastUndefinedRegionOffset, node.getEndOffset() - lastUndefinedRegionOffset);</TD></TR><TR CLASS="z"><TD CLASS="l">325</TD><TD> stringBuffer.append(undefinedRegion);</TD></TR><TR><TD CLASS="l">326</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">327</TD><TD> IDOMModel structuredModel = node.getModel();</TD></TR><TR CLASS="z"><TD CLASS="l">328</TD><TD> IStructuredDocument structuredDocument = structuredModel.getStructuredDocument();</TD></TR><TR><TD CLASS="l">329</TD><TD> // 1 is for "<"</TD></TR><TR CLASS="z"><TD CLASS="l">330</TD><TD> int offset = node.getStartOffset() + 1 + node.getNodeName().length();</TD></TR><TR><TD CLASS="l">331</TD><TD> // 1 is for "<"</TD></TR><TR CLASS="z"><TD CLASS="l">332</TD><TD> int length = node.getFirstStructuredDocumentRegion().getTextLength() - 1 - node.getNodeName().length();</TD></TR><TR><TD CLASS="l">333</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">334</TD><TD> if (flatNode != null) {</TD></TR><TR CLASS="z"><TD CLASS="l">335</TD><TD> ITextRegionList regions = flatNode.getRegions();</TD></TR><TR CLASS="z"><TD CLASS="l">336</TD><TD> ITextRegion firstRegion = regions.get(0);</TD></TR><TR CLASS="z"><TD CLASS="l">337</TD><TD> ITextRegion lastRegion = regions.get(regions.size() - 1);</TD></TR><TR><TD CLASS="l">338</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">339</TD><TD> if (firstRegion.getType() == DOMRegionContext.XML_END_TAG_OPEN)</TD></TR><TR><TD CLASS="l">340</TD><TD> // skip formatting for end tags in this format: </tagName></TD></TR><TR CLASS="z"><TD CLASS="l">341</TD><TD> return;</TD></TR><TR><TD CLASS="l">342</TD><TD> else {</TD></TR><TR CLASS="z"><TD CLASS="l">343</TD><TD> if (lastRegion.getType() == DOMRegionContext.XML_TAG_CLOSE || lastRegion.getType() == DOMRegionContext.XML_EMPTY_TAG_CLOSE)</TD></TR><TR CLASS="z"><TD CLASS="l">344</TD><TD> length = length - lastRegion.getLength();</TD></TR><TR><TD CLASS="l">345</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">346</TD><TD> if (lastRegion.getType() == DOMRegionContext.XML_EMPTY_TAG_CLOSE) {</TD></TR><TR><TD CLASS="l">347</TD><TD> // leave space before XML_EMPTY_TAG_CLOSE: <tagName /></TD></TR><TR><TD CLASS="l">348</TD><TD> // unless already going to move end bracket</TD></TR><TR CLASS="z"><TD CLASS="l">349</TD><TD> if (!startTagSpansOver1Line || !alignEndBracket)</TD></TR><TR CLASS="z"><TD CLASS="l">350</TD><TD> stringBuffer.append(SPACE_CHAR);</TD></TR><TR><TD CLASS="l">351</TD><TD> }</TD></TR><TR><TD CLASS="l">352</TD><TD> }</TD></TR><TR><TD CLASS="l">353</TD><TD> }</TD></TR><TR><TD CLASS="l">354</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">355</TD><TD> if (startTagSpansOver1Line && alignEndBracket) {</TD></TR><TR CLASS="z"><TD CLASS="l">356</TD><TD> stringBuffer.append(lineDelimiter).append(lineIndent);</TD></TR><TR><TD CLASS="l">357</TD><TD> }</TD></TR><TR><TD CLASS="l">358</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">359</TD><TD> replace(structuredDocument, offset, length, stringBuffer.toString());</TD></TR><TR><TD CLASS="l">360</TD><TD> </TD></TR><TR><TD CLASS="l">361</TD><TD> // BUG108074 & BUG84688 - preserve whitespace in xsl:text &</TD></TR><TR><TD CLASS="l">362</TD><TD> // xsl:attribute</TD></TR><TR CLASS="z"><TD CLASS="l">363</TD><TD> String nodeNamespaceURI = node.getNamespaceURI();</TD></TR><TR CLASS="z"><TD CLASS="l">364</TD><TD> if (XSL_NAMESPACE.equals(nodeNamespaceURI)) {</TD></TR><TR CLASS="z"><TD CLASS="l">365</TD><TD> String nodeName = ((Element) node).getLocalName();</TD></TR><TR CLASS="z"><TD CLASS="l">366</TD><TD> if (XSL_ATTRIBUTE.equals(nodeName) || XSL_TEXT.equals(nodeName)) {</TD></TR><TR CLASS="z"><TD CLASS="l">367</TD><TD> sawXmlSpace = true;</TD></TR><TR CLASS="z"><TD CLASS="l">368</TD><TD> formatContraints.setInPreserveSpaceElement(true);</TD></TR><TR><TD CLASS="l">369</TD><TD> }</TD></TR><TR><TD CLASS="l">370</TD><TD> }</TD></TR><TR><TD CLASS="l">371</TD><TD> </TD></TR><TR><TD CLASS="l">372</TD><TD> // If we didn't see a xml:space attribute above, we'll look for</TD></TR><TR><TD CLASS="l">373</TD><TD> // one in the DTD.</TD></TR><TR><TD CLASS="l">374</TD><TD> // We do not check for a conflict between a DTD's 'fixed' value</TD></TR><TR><TD CLASS="l">375</TD><TD> // and the attribute value found in the instance document, we</TD></TR><TR><TD CLASS="l">376</TD><TD> // leave that to the validator.</TD></TR><TR CLASS="z"><TD CLASS="l">377</TD><TD> if (!sawXmlSpace) {</TD></TR><TR CLASS="z"><TD CLASS="l">378</TD><TD> ModelQueryAdapter adapter = (ModelQueryAdapter) ((IDOMDocument) node.getOwnerDocument()).getAdapterFor(ModelQueryAdapter.class);</TD></TR><TR CLASS="z"><TD CLASS="l">379</TD><TD> CMElementDeclaration elementDeclaration = (CMElementDeclaration) adapter.getModelQuery().getCMNode(node);</TD></TR><TR CLASS="z"><TD CLASS="l">380</TD><TD> if (elementDeclaration != null) {</TD></TR><TR CLASS="z"><TD CLASS="l">381</TD><TD> int contentType = elementDeclaration.getContentType();</TD></TR><TR CLASS="z"><TD CLASS="l">382</TD><TD> if (preferences.isPreservePCDATAContent() && contentType == CMElementDeclaration.PCDATA) {</TD></TR><TR CLASS="z"><TD CLASS="l">383</TD><TD> formatContraints.setInPreserveSpaceElement(true);</TD></TR><TR><TD CLASS="l">384</TD><TD> }</TD></TR><TR><TD CLASS="l">385</TD><TD> else {</TD></TR><TR CLASS="z"><TD CLASS="l">386</TD><TD> CMNamedNodeMap cmAttributes = elementDeclaration.getAttributes();</TD></TR><TR><TD CLASS="l">387</TD><TD> // Check implied values from the DTD way.</TD></TR><TR CLASS="z"><TD CLASS="l">388</TD><TD> CMAttributeDeclaration attributeDeclaration = (CMAttributeDeclaration) cmAttributes.getNamedItem(XML_SPACE);</TD></TR><TR CLASS="z"><TD CLASS="l">389</TD><TD> if (attributeDeclaration != null) {</TD></TR><TR><TD CLASS="l">390</TD><TD> // CMAttributeDeclaration found, check it out.</TD></TR><TR CLASS="z"><TD CLASS="l">391</TD><TD> String defaultValue = attributeDeclaration.getAttrType().getImpliedValue();</TD></TR><TR><TD CLASS="l">392</TD><TD> </TD></TR><TR><TD CLASS="l">393</TD><TD> // xml:space="preserve" means preserve space,</TD></TR><TR><TD CLASS="l">394</TD><TD> // everything else means back to default.</TD></TR><TR CLASS="z"><TD CLASS="l">395</TD><TD> if (PRESERVE.compareTo(defaultValue) == 0)</TD></TR><TR CLASS="z"><TD CLASS="l">396</TD><TD> formatContraints.setInPreserveSpaceElement(true);</TD></TR><TR><TD CLASS="l">397</TD><TD> else</TD></TR><TR CLASS="z"><TD CLASS="l">398</TD><TD> formatContraints.setInPreserveSpaceElement(false);</TD></TR><TR><TD CLASS="l">399</TD><TD> }</TD></TR><TR><TD CLASS="l">400</TD><TD> }</TD></TR><TR><TD CLASS="l">401</TD><TD> }</TD></TR><TR><TD CLASS="l">402</TD><TD> }</TD></TR><TR><TD CLASS="l"><A NAME="5">403</A></TD><TD> }</TD></TR><TR CLASS="z"><TD CLASS="l">404</TD><TD> }</TD></TR><TR><TD CLASS="l">405</TD><TD> </TD></TR><TR><TD CLASS="l">406</TD><TD> protected String getUndefinedRegions(IDOMNode node, int startOffset, int length) {</TD></TR><TR CLASS="z"><TD CLASS="l">407</TD><TD> String result = new String();</TD></TR><TR><TD CLASS="l">408</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">409</TD><TD> IStructuredDocumentRegion flatNode = node.getFirstStructuredDocumentRegion();</TD></TR><TR CLASS="z"><TD CLASS="l">410</TD><TD> ITextRegionList regions = flatNode.getRegions();</TD></TR><TR CLASS="z"><TD CLASS="l">411</TD><TD> for (int i = 0; i < regions.size(); i++) {</TD></TR><TR CLASS="z"><TD CLASS="l">412</TD><TD> ITextRegion region = regions.get(i);</TD></TR><TR CLASS="z"><TD CLASS="l">413</TD><TD> String regionType = region.getType();</TD></TR><TR CLASS="z"><TD CLASS="l">414</TD><TD> int regionStartOffset = flatNode.getStartOffset(region);</TD></TR><TR><TD CLASS="l">415</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">416</TD><TD> if (regionType.compareTo(DOMRegionContext.UNDEFINED) == 0 && regionStartOffset >= startOffset && regionStartOffset < startOffset + length)</TD></TR><TR CLASS="z"><TD CLASS="l">417</TD><TD> result = result + flatNode.getFullText(region);</TD></TR><TR><TD CLASS="l">418</TD><TD> }</TD></TR><TR><TD CLASS="l">419</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">420</TD><TD> if (result.length() > 0)</TD></TR><TR CLASS="z"><TD CLASS="l">421</TD><TD> return SPACE_CHAR + result.trim();</TD></TR><TR><TD CLASS="l">422</TD><TD> else</TD></TR><TR CLASS="z"><TD CLASS="l">423</TD><TD> return result;</TD></TR><TR><TD CLASS="l">424</TD><TD> }</TD></TR><TR><TD CLASS="l">425</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="27.html">org.eclipse.wst.xml.core.internal.provisional.format</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> |