Added: 
websites/production/commons/content/proper/commons-csv/cobertura/org.apache.commons.csv.Lexer.html
==============================================================================
--- 
websites/production/commons/content/proper/commons-csv/cobertura/org.apache.commons.csv.Lexer.html
 (added)
+++ 
websites/production/commons/content/proper/commons-csv/cobertura/org.apache.commons.csv.Lexer.html
 Wed Nov 26 16:11:26 2014
@@ -0,0 +1,776 @@
+<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
+           "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd";>
+<html>
+<head>
+<meta http-equiv="Content-Type" content="text/html; charset=UTF-8"/>
+<title>Coverage Report</title>
+<link title="Style" type="text/css" rel="stylesheet" href="css/main.css"/>
+<script type="text/javascript" src="js/popup.js"></script>
+</head>
+<body>
+<h5>Coverage Report - org.apache.commons.csv.Lexer</h5>
+<div class="separator">&nbsp;</div>
+<table class="report">
+<thead><tr>  <td class="heading">Classes in this File</td>  <td 
class="heading"><a class="dfn" href="help.html" 
onclick="popupwindow('help.html'); return false;">Line Coverage</a></td>  <td 
class="heading"><a class="dfn" href="help.html" 
onclick="popupwindow('help.html'); return false;">Branch Coverage</a></td>  <td 
class="heading"><a class="dfn" href="help.html" 
onclick="popupwindow('help.html'); return 
false;">Complexity</a></td></tr></thead>
+  <tr><td><a href="org.apache.commons.csv.Lexer.html">Lexer</a></td><td><table 
cellpadding="0px" cellspacing="0px" class="percentgraph"><tr 
class="percentgraph"><td align="right" class="percentgraph" 
width="40">93%</td><td class="percentgraph"><div class="percentgraph"><div 
class="greenbar" style="width:93px"><span 
class="text">124/132</span></div></div></td></tr></table></td><td><table 
cellpadding="0px" cellspacing="0px" class="percentgraph"><tr 
class="percentgraph"><td align="right" class="percentgraph" 
width="40">92%</td><td class="percentgraph"><div class="percentgraph"><div 
class="greenbar" style="width:92px"><span 
class="text">111/120</span></div></div></td></tr></table></td><td 
class="value"><span class="hidden">4.9;</span>4.9</td></tr>
+
+</table>
+<div class="separator">&nbsp;</div>
+<table cellspacing="0" cellpadding="0" class="src">
+<tr>  <td class="numLine">&nbsp;1</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span 
class="comment">/*</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;2</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span class="comment"> * Licensed to 
the Apache Software Foundation (ASF) under one or more</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;3</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span class="comment"> * contributor 
license agreements.  See the NOTICE file distributed with</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;4</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span class="comment"> * this work 
for additional information regarding copyright ownership.</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;5</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span class="comment"> * The ASF 
licenses this file to You under the Apache License, Version 
2.0</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;6</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span class="comment"> * (the 
"License"); you may not use this file except in compliance 
with</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;7</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span class="comment"> * the License. 
 You may obtain a copy of the License at</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;8</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span class="comment"> 
*</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;9</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span class="comment"> *      
http://www.apache.org/licenses/LICENSE-2.0</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;10</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span class="comment"> 
*</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;11</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span class="comment"> * Unless 
required by applicable law or agreed to in writing, 
software</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;12</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span class="comment"> * distributed 
under the License is distributed on an "AS IS" BASIS,</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;13</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span class="comment"> * WITHOUT 
WARRANTIES OR CONDITIONS OF ANY KIND, either express or 
implied.</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;14</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span class="comment"> * See the 
License for the specific language governing permissions 
and</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;15</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span class="comment"> * limitations 
under the License.</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;16</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span class="comment"> 
*/</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;17</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;18</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span class="keyword">package</span> 
org.apache.commons.csv;</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;19</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;20</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span class="keyword">import</span> 
<span class="keyword">static</span> 
org.apache.commons.csv.Constants.BACKSPACE;</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;21</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span class="keyword">import</span> 
<span class="keyword">static</span> 
org.apache.commons.csv.Constants.CR;</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;22</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span class="keyword">import</span> 
<span class="keyword">static</span> 
org.apache.commons.csv.Constants.END_OF_STREAM;</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;23</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span class="keyword">import</span> 
<span class="keyword">static</span> 
org.apache.commons.csv.Constants.FF;</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;24</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span class="keyword">import</span> 
<span class="keyword">static</span> 
org.apache.commons.csv.Constants.LF;</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;25</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span class="keyword">import</span> 
<span class="keyword">static</span> 
org.apache.commons.csv.Constants.TAB;</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;26</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span class="keyword">import</span> 
<span class="keyword">static</span> 
org.apache.commons.csv.Constants.UNDEFINED;</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;27</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span class="keyword">import</span> 
<span class="keyword">static</span> 
org.apache.commons.csv.Token.Type.COMMENT;</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;28</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span class="keyword">import</span> 
<span class="keyword">static</span> 
org.apache.commons.csv.Token.Type.EOF;</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;29</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span class="keyword">import</span> 
<span class="keyword">static</span> 
org.apache.commons.csv.Token.Type.EORECORD;</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;30</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span class="keyword">import</span> 
<span class="keyword">static</span> 
org.apache.commons.csv.Token.Type.INVALID;</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;31</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span class="keyword">import</span> 
<span class="keyword">static</span> 
org.apache.commons.csv.Token.Type.TOKEN;</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;32</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;33</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span class="keyword">import</span> 
java.io.Closeable;</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;34</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span class="keyword">import</span> 
java.io.IOException;</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;35</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;36</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span 
class="comment">/**</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;37</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span class="comment"> * Lexical 
analyzer.</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;38</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span class="comment"> 
*</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;39</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span class="comment"> * @version 
$Id$</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;40</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span class="comment"> 
*/</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;41</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span class="keyword">final</span> 
<span class="keyword">class</span> Lexer <span 
class="keyword">implements</span> Closeable {</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;42</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;43</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;    <span 
class="comment">/**</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;44</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span class="comment">     * Constant 
char to use for disabling comments, escapes and encapsulation. The value -2 is 
used because it</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;45</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span class="comment">     * won't be 
confused with an EOF signal (-1), and because the Unicode value {@code FFFE} 
would be encoded as two</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;46</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span class="comment">     * chars 
(using surrogates) and thus there should never be a collision with a real text 
char.</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;47</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span class="comment">     
*/</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;48</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;    <span 
class="keyword">private</span> <span class="keyword">static</span> <span 
class="keyword">final</span> <span class="keyword">char</span> DISABLED = <span 
class="string">'\ufffe'</span>;</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;49</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;50</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;    <span 
class="keyword">private</span> <span class="keyword">final</span> <span 
class="keyword">char</span> delimiter;</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;51</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;    <span 
class="keyword">private</span> <span class="keyword">final</span> <span 
class="keyword">char</span> escape;</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;52</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;    <span 
class="keyword">private</span> <span class="keyword">final</span> <span 
class="keyword">char</span> quoteChar;</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;53</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;    <span 
class="keyword">private</span> <span class="keyword">final</span> <span 
class="keyword">char</span> commentStart;</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;54</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;55</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;    <span 
class="keyword">private</span> <span class="keyword">final</span> <span 
class="keyword">boolean</span> ignoreSurroundingSpaces;</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;56</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;    <span 
class="keyword">private</span> <span class="keyword">final</span> <span 
class="keyword">boolean</span> ignoreEmptyLines;</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;57</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;58</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;    <span class="comment">/** The 
input stream */</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;59</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;    <span 
class="keyword">private</span> <span class="keyword">final</span> 
ExtendedBufferedReader reader;</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;60</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;</pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;61</td>  <td 
class="nbHitsCovered">&nbsp;30115</td>  <td class="src"><pre class="src">&nbsp; 
   Lexer(<span class="keyword">final</span> CSVFormat format, <span 
class="keyword">final</span> ExtendedBufferedReader reader) {</pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;62</td>  <td 
class="nbHitsCovered">&nbsp;30115</td>  <td class="src"><pre class="src">&nbsp; 
       <span class="keyword">this</span>.reader = reader;</pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;63</td>  <td 
class="nbHitsCovered">&nbsp;30115</td>  <td class="src"><pre class="src">&nbsp; 
       <span class="keyword">this</span>.delimiter = 
format.getDelimiter();</pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;64</td>  <td 
class="nbHitsCovered">&nbsp;30115</td>  <td class="src"><pre class="src">&nbsp; 
       <span class="keyword">this</span>.escape = 
mapNullToDisabled(format.getEscapeCharacter());</pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;65</td>  <td 
class="nbHitsCovered">&nbsp;30115</td>  <td class="src"><pre class="src">&nbsp; 
       <span class="keyword">this</span>.quoteChar = 
mapNullToDisabled(format.getQuoteCharacter());</pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;66</td>  <td 
class="nbHitsCovered">&nbsp;30115</td>  <td class="src"><pre class="src">&nbsp; 
       <span class="keyword">this</span>.commentStart = 
mapNullToDisabled(format.getCommentMarker());</pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;67</td>  <td 
class="nbHitsCovered">&nbsp;30115</td>  <td class="src"><pre class="src">&nbsp; 
       <span class="keyword">this</span>.ignoreSurroundingSpaces = 
format.getIgnoreSurroundingSpaces();</pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;68</td>  <td 
class="nbHitsCovered">&nbsp;30115</td>  <td class="src"><pre class="src">&nbsp; 
       <span class="keyword">this</span>.ignoreEmptyLines = 
format.getIgnoreEmptyLines();</pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;69</td>  <td 
class="nbHitsCovered">&nbsp;30115</td>  <td class="src"><pre class="src">&nbsp; 
   }</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;70</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;71</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;    <span 
class="comment">/**</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;72</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span class="comment">     * Returns 
the next token.</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;73</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span class="comment">     * 
&lt;p&gt;</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;74</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span class="comment">     * A token 
corresponds to a term, a record change or an end-of-file 
indicator.</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;75</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span class="comment">     * 
&lt;/p&gt;</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;76</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span class="comment">     
*</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;77</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span class="comment">     * @param 
token</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;78</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span class="comment">     *          
  an existing Token object to reuse. The caller is responsible to initialize 
the Token.</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;79</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span class="comment">     * @return 
the next token found</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;80</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span class="comment">     * @throws 
java.io.IOException</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;81</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span class="comment">     *          
   on stream access error</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;82</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span class="comment">     
*/</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;83</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;    Token nextToken(<span 
class="keyword">final</span> Token token) <span class="keyword">throws</span> 
IOException {</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;84</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;85</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;        <span class="comment">// get 
the last read char (required for empty line detection)</span></pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;86</td>  <td 
class="nbHitsCovered">&nbsp;183394</td>  <td class="src"><pre 
class="src">&nbsp;        <span class="keyword">int</span> lastChar = 
reader.getLastChar();</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;87</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;88</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;        <span class="comment">// read 
the next char and set eol</span></pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;89</td>  <td 
class="nbHitsCovered">&nbsp;183394</td>  <td class="src"><pre 
class="src">&nbsp;        <span class="keyword">int</span> c = 
reader.read();</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;90</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;        <span 
class="comment">/*</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;91</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span class="comment">         * 
Note: The following call will swallow LF if c == CR. But we don't need to know 
if the last char was CR or LF</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;92</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span class="comment">         * - 
they are equivalent here.</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;93</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span class="comment">         
*/</span></pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;94</td>  <td 
class="nbHitsCovered">&nbsp;183394</td>  <td class="src"><pre 
class="src">&nbsp;        <span class="keyword">boolean</span> eol = 
readEndOfLine(c);</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;95</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;96</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;        <span class="comment">// 
empty line detection: eol AND (last char was EOL or 
beginning)</span></pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;97</td>  <td class="nbHitsCovered"><a 
title="Line 97: Conditional coverage 100% (2/2).">&nbsp;183394</a></td>  <td 
class="src"><pre class="src">&nbsp;<a title="Line 97: Conditional coverage 100% 
(2/2).">        <span class="keyword">if</span> (ignoreEmptyLines) 
{</a></pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;98</td>  <td class="nbHitsCovered"><a 
title="Line 98: Conditional coverage 100% (4/4) [each condition: 100%, 
100%].">&nbsp;61896</a></td>  <td class="src"><pre class="src">&nbsp;<a 
title="Line 98: Conditional coverage 100% (4/4) [each condition: 100%, 100%]."> 
           <span class="keyword">while</span> (eol &amp;&amp; 
isStartOfLine(lastChar)) {</a></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;99</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;                <span 
class="comment">// go on char ahead ...</span></pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;100</td>  <td 
class="nbHitsCovered">&nbsp;43</td>  <td class="src"><pre class="src">&nbsp;    
            lastChar = c;</pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;101</td>  <td 
class="nbHitsCovered">&nbsp;43</td>  <td class="src"><pre class="src">&nbsp;    
            c = reader.read();</pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;102</td>  <td 
class="nbHitsCovered">&nbsp;43</td>  <td class="src"><pre class="src">&nbsp;    
            eol = readEndOfLine(c);</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;103</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;                <span 
class="comment">// reached end of file without any content (empty line at the 
end)</span></pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;104</td>  <td class="nbHitsCovered"><a 
title="Line 104: Conditional coverage 100% (2/2).">&nbsp;43</a></td>  <td 
class="src"><pre class="src">&nbsp;<a title="Line 104: Conditional coverage 
100% (2/2).">                <span class="keyword">if</span> (isEndOfFile(c)) 
{</a></pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;105</td>  <td 
class="nbHitsCovered">&nbsp;6</td>  <td class="src"><pre class="src">&nbsp;     
               token.type = EOF;</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;106</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;                    <span 
class="comment">// don't set token.isReady here because no 
content</span></pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;107</td>  <td 
class="nbHitsCovered">&nbsp;6</td>  <td class="src"><pre class="src">&nbsp;     
               <span class="keyword">return</span> token;</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;108</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;                }</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;109</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;            }</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;110</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;        }</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;111</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;112</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;        <span class="comment">// did 
we reach eof during the last iteration already ? EOF</span></pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;113</td>  <td class="nbHitsCovered"><a 
title="Line 113: Conditional coverage 100% (6/6) [each condition: 100%, 100%, 
100%].">&nbsp;183388</a></td>  <td class="src"><pre class="src">&nbsp;<a 
title="Line 113: Conditional coverage 100% (6/6) [each condition: 100%, 100%, 
100%].">        <span class="keyword">if</span> (isEndOfFile(lastChar) || 
(!isDelimiter(lastChar) &amp;&amp; isEndOfFile(c))) {</a></pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;114</td>  <td 
class="nbHitsCovered">&nbsp;30074</td>  <td class="src"><pre class="src">&nbsp; 
           token.type = EOF;</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;115</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;            <span class="comment">// 
don't set token.isReady here because no content</span></pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;116</td>  <td 
class="nbHitsCovered">&nbsp;30074</td>  <td class="src"><pre class="src">&nbsp; 
           <span class="keyword">return</span> token;</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;117</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;        }</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;118</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;</pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;119</td>  <td class="nbHitsCovered"><a 
title="Line 119: Conditional coverage 100% (4/4) [each condition: 100%, 
100%].">&nbsp;153314</a></td>  <td class="src"><pre class="src">&nbsp;<a 
title="Line 119: Conditional coverage 100% (4/4) [each condition: 100%, 
100%].">        <span class="keyword">if</span> (isStartOfLine(lastChar) 
&amp;&amp; isCommentStart(c)) {</a></pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;120</td>  <td 
class="nbHitsCovered">&nbsp;44</td>  <td class="src"><pre class="src">&nbsp;    
        <span class="keyword">final</span> String line = 
reader.readLine();</pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;121</td>  <td class="nbHitsUncovered"><a 
title="Line 121: Conditional coverage 50% (1/2).">&nbsp;44</a></td>  <td 
class="src"><pre class="src"><span class="srcUncovered">&nbsp;<a title="Line 
121: Conditional coverage 50% (1/2).">            <span 
class="keyword">if</span> (line == <span class="keyword">null</span>) 
{</a></span></pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;122</td>  <td 
class="nbHitsUncovered">&nbsp;0</td>  <td class="src"><pre class="src"><span 
class="srcUncovered">&nbsp;                token.type = 
EOF;</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;123</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;                <span 
class="comment">// don't set token.isReady here because no 
content</span></pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;124</td>  <td 
class="nbHitsUncovered">&nbsp;0</td>  <td class="src"><pre class="src"><span 
class="srcUncovered">&nbsp;                <span class="keyword">return</span> 
token;</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;125</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;            }</pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;126</td>  <td 
class="nbHitsCovered">&nbsp;44</td>  <td class="src"><pre class="src">&nbsp;    
        <span class="keyword">final</span> String comment = 
line.trim();</pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;127</td>  <td 
class="nbHitsCovered">&nbsp;44</td>  <td class="src"><pre class="src">&nbsp;    
        token.content.append(comment);</pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;128</td>  <td 
class="nbHitsCovered">&nbsp;44</td>  <td class="src"><pre class="src">&nbsp;    
        token.type = COMMENT;</pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;129</td>  <td 
class="nbHitsCovered">&nbsp;44</td>  <td class="src"><pre class="src">&nbsp;    
        <span class="keyword">return</span> token;</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;130</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;        }</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;131</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;132</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;        <span class="comment">// 
important: make sure a new char gets consumed in each 
iteration</span></pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;133</td>  <td class="nbHitsCovered"><a 
title="Line 133: Conditional coverage 100% (2/2).">&nbsp;306539</a></td>  <td 
class="src"><pre class="src">&nbsp;<a title="Line 133: Conditional coverage 
100% (2/2).">        <span class="keyword">while</span> (token.type == INVALID) 
{</a></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;134</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;            <span class="comment">// 
ignore whitespaces at beginning of a token</span></pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;135</td>  <td class="nbHitsCovered"><a 
title="Line 135: Conditional coverage 100% (2/2).">&nbsp;153270</a></td>  <td 
class="src"><pre class="src">&nbsp;<a title="Line 135: Conditional coverage 
100% (2/2).">            <span class="keyword">if</span> 
(ignoreSurroundingSpaces) {</a></pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;136</td>  <td class="nbHitsCovered"><a 
title="Line 136: Conditional coverage 100% (4/4) [each condition: 100%, 
100%].">&nbsp;165</a></td>  <td class="src"><pre class="src">&nbsp;<a 
title="Line 136: Conditional coverage 100% (4/4) [each condition: 100%, 
100%].">                <span class="keyword">while</span> (isWhitespace(c) 
&amp;&amp; !eol) {</a></pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;137</td>  <td 
class="nbHitsCovered">&nbsp;39</td>  <td class="src"><pre class="src">&nbsp;    
                c = reader.read();</pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;138</td>  <td 
class="nbHitsCovered">&nbsp;39</td>  <td class="src"><pre class="src">&nbsp;    
                eol = readEndOfLine(c);</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;139</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;                }</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;140</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;            }</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;141</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;142</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;            <span class="comment">// 
ok, start of token reached: encapsulated, or token</span></pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;143</td>  <td class="nbHitsCovered"><a 
title="Line 143: Conditional coverage 100% (2/2).">&nbsp;153270</a></td>  <td 
class="src"><pre class="src">&nbsp;<a title="Line 143: Conditional coverage 
100% (2/2).">            <span class="keyword">if</span> (isDelimiter(c)) 
{</a></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;144</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;                <span 
class="comment">// empty token return TOKEN("")</span></pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;145</td>  <td 
class="nbHitsCovered">&nbsp;2322</td>  <td class="src"><pre class="src">&nbsp;  
              token.type = TOKEN;</pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;146</td>  <td class="nbHitsCovered"><a 
title="Line 146: Conditional coverage 100% (2/2).">&nbsp;150948</a></td>  <td 
class="src"><pre class="src">&nbsp;<a title="Line 146: Conditional coverage 
100% (2/2).">            } <span class="keyword">else</span> <span 
class="keyword">if</span> (eol) {</a></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;147</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;                <span 
class="comment">// empty token return EORECORD("")</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;148</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;                <span 
class="comment">// noop: token.content.append("");</span></pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;149</td>  <td 
class="nbHitsCovered">&nbsp;3058</td>  <td class="src"><pre class="src">&nbsp;  
              token.type = EORECORD;</pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;150</td>  <td class="nbHitsCovered"><a 
title="Line 150: Conditional coverage 100% (2/2).">&nbsp;147890</a></td>  <td 
class="src"><pre class="src">&nbsp;<a title="Line 150: Conditional coverage 
100% (2/2).">            } <span class="keyword">else</span> <span 
class="keyword">if</span> (isQuoteChar(c)) {</a></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;151</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;                <span 
class="comment">// consume encapsulated token</span></pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;152</td>  <td 
class="nbHitsCovered">&nbsp;90997</td>  <td class="src"><pre class="src">&nbsp; 
               parseEncapsulatedToken(token);</pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;153</td>  <td class="nbHitsCovered"><a 
title="Line 153: Conditional coverage 100% (2/2).">&nbsp;56893</a></td>  <td 
class="src"><pre class="src">&nbsp;<a title="Line 153: Conditional coverage 
100% (2/2).">            } <span class="keyword">else</span> <span 
class="keyword">if</span> (isEndOfFile(c)) {</a></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;154</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;                <span 
class="comment">// end of file return EOF()</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;155</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;                <span 
class="comment">// noop: token.content.append("");</span></pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;156</td>  <td 
class="nbHitsCovered">&nbsp;7</td>  <td class="src"><pre class="src">&nbsp;     
           token.type = EOF;</pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;157</td>  <td 
class="nbHitsCovered">&nbsp;7</td>  <td class="src"><pre class="src">&nbsp;     
           token.isReady = <span class="keyword">true</span>; <span 
class="comment">// there is data at EOF</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;158</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;            } <span 
class="keyword">else</span> {</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;159</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;                <span 
class="comment">// next token must be a simple token</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;160</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;                <span 
class="comment">// add removed blanks when not ignoring whitespace 
chars...</span></pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;161</td>  <td 
class="nbHitsCovered">&nbsp;56886</td>  <td class="src"><pre class="src">&nbsp; 
               parseSimpleToken(token, c);</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;162</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;            }</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;163</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;        }</pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;164</td>  <td 
class="nbHitsCovered">&nbsp;153269</td>  <td class="src"><pre 
class="src">&nbsp;        <span class="keyword">return</span> 
token;</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;165</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;    }</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;166</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;167</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;    <span 
class="comment">/**</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;168</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span class="comment">     * Parses a 
simple token.</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;169</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span class="comment">     * 
&lt;p/&gt;</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;170</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span class="comment">     * Simple 
token are tokens which are not surrounded by encapsulators. A simple token 
might contain escaped</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;171</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span class="comment">     * 
delimiters (as \, or \;). The token is finished when one of the following 
conditions become true:</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;172</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span class="comment">     * 
&lt;ul&gt;</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;173</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span class="comment">     * 
&lt;li&gt;end of line has been reached 
(EORECORD)&lt;/li&gt;</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;174</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span class="comment">     * 
&lt;li&gt;end of stream has been reached (EOF)&lt;/li&gt;</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;175</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span class="comment">     * 
&lt;li&gt;an unescaped delimiter has been reached 
(TOKEN)&lt;/li&gt;</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;176</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span class="comment">     * 
&lt;/ul&gt;</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;177</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span class="comment">     
*</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;178</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span class="comment">     * @param 
token</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;179</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span class="comment">     *          
  the current token</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;180</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span class="comment">     * @param 
ch</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;181</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span class="comment">     *          
  the current character</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;182</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span class="comment">     * @return 
the filled token</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;183</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span class="comment">     * @throws 
IOException</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;184</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span class="comment">     *          
   on stream access error</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;185</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span class="comment">     
*/</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;186</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;    <span 
class="keyword">private</span> Token parseSimpleToken(<span 
class="keyword">final</span> Token token, <span class="keyword">int</span> ch) 
<span class="keyword">throws</span> IOException {</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;187</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;        <span class="comment">// 
Faster to use while(true)+break than while(token.type == 
INVALID)</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;188</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;        <span 
class="keyword">while</span> (<span class="keyword">true</span>) 
{</pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;189</td>  <td class="nbHitsCovered"><a 
title="Line 189: Conditional coverage 100% (2/2).">&nbsp;576765</a></td>  <td 
class="src"><pre class="src">&nbsp;<a title="Line 189: Conditional coverage 
100% (2/2).">            <span class="keyword">if</span> (readEndOfLine(ch)) 
{</a></pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;190</td>  <td 
class="nbHitsCovered">&nbsp;28110</td>  <td class="src"><pre class="src">&nbsp; 
               token.type = EORECORD;</pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;191</td>  <td 
class="nbHitsCovered">&nbsp;28110</td>  <td class="src"><pre class="src">&nbsp; 
               <span class="keyword">break</span>;</pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;192</td>  <td class="nbHitsCovered"><a 
title="Line 192: Conditional coverage 100% (2/2).">&nbsp;548655</a></td>  <td 
class="src"><pre class="src">&nbsp;<a title="Line 192: Conditional coverage 
100% (2/2).">            } <span class="keyword">else</span> <span 
class="keyword">if</span> (isEndOfFile(ch)) {</a></pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;193</td>  <td 
class="nbHitsCovered">&nbsp;45</td>  <td class="src"><pre class="src">&nbsp;    
            token.type = EOF;</pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;194</td>  <td 
class="nbHitsCovered">&nbsp;45</td>  <td class="src"><pre class="src">&nbsp;    
            token.isReady = <span class="keyword">true</span>; <span 
class="comment">// There is data at EOF</span></pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;195</td>  <td 
class="nbHitsCovered">&nbsp;45</td>  <td class="src"><pre class="src">&nbsp;    
            <span class="keyword">break</span>;</pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;196</td>  <td class="nbHitsCovered"><a 
title="Line 196: Conditional coverage 100% (2/2).">&nbsp;548610</a></td>  <td 
class="src"><pre class="src">&nbsp;<a title="Line 196: Conditional coverage 
100% (2/2).">            } <span class="keyword">else</span> <span 
class="keyword">if</span> (isDelimiter(ch)) {</a></pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;197</td>  <td 
class="nbHitsCovered">&nbsp;28730</td>  <td class="src"><pre class="src">&nbsp; 
               token.type = TOKEN;</pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;198</td>  <td 
class="nbHitsCovered">&nbsp;28730</td>  <td class="src"><pre class="src">&nbsp; 
               <span class="keyword">break</span>;</pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;199</td>  <td class="nbHitsCovered"><a 
title="Line 199: Conditional coverage 100% (2/2).">&nbsp;519880</a></td>  <td 
class="src"><pre class="src">&nbsp;<a title="Line 199: Conditional coverage 
100% (2/2).">            } <span class="keyword">else</span> <span 
class="keyword">if</span> (isEscape(ch)) {</a></pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;200</td>  <td 
class="nbHitsCovered">&nbsp;96987</td>  <td class="src"><pre class="src">&nbsp; 
               <span class="keyword">final</span> <span 
class="keyword">int</span> unescaped = readEscape();</pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;201</td>  <td class="nbHitsCovered"><a 
title="Line 201: Conditional coverage 100% (2/2).">&nbsp;96986</a></td>  <td 
class="src"><pre class="src">&nbsp;<a title="Line 201: Conditional coverage 
100% (2/2).">                <span class="keyword">if</span> (unescaped == 
Constants.END_OF_STREAM) { <span class="comment">// unexpected char after 
escape</span></a></pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;202</td>  <td 
class="nbHitsCovered">&nbsp;3</td>  <td class="src"><pre class="src">&nbsp;     
               token.content.append((<span class="keyword">char</span>) 
ch).append((<span class="keyword">char</span>) 
reader.getLastChar());</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;203</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;                } <span 
class="keyword">else</span> {</pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;204</td>  <td 
class="nbHitsCovered">&nbsp;96983</td>  <td class="src"><pre class="src">&nbsp; 
                   token.content.append((<span class="keyword">char</span>) 
unescaped);</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;205</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;                }</pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;206</td>  <td 
class="nbHitsCovered">&nbsp;96986</td>  <td class="src"><pre class="src">&nbsp; 
               ch = reader.read(); <span class="comment">// 
continue</span></pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;207</td>  <td 
class="nbHitsCovered">&nbsp;96986</td>  <td class="src"><pre class="src">&nbsp; 
           } <span class="keyword">else</span> {</pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;208</td>  <td 
class="nbHitsCovered">&nbsp;422893</td>  <td class="src"><pre 
class="src">&nbsp;                token.content.append((<span 
class="keyword">char</span>) ch);</pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;209</td>  <td 
class="nbHitsCovered">&nbsp;422893</td>  <td class="src"><pre 
class="src">&nbsp;                ch = reader.read(); <span class="comment">// 
continue</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;210</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;            }</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;211</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;        }</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;212</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;</pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;213</td>  <td class="nbHitsCovered"><a 
title="Line 213: Conditional coverage 100% (2/2).">&nbsp;56885</a></td>  <td 
class="src"><pre class="src">&nbsp;<a title="Line 213: Conditional coverage 
100% (2/2).">        <span class="keyword">if</span> (ignoreSurroundingSpaces) 
{</a></pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;214</td>  <td 
class="nbHitsCovered">&nbsp;77</td>  <td class="src"><pre class="src">&nbsp;    
        trimTrailingSpaces(token.content);</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;215</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;        }</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;216</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;</pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;217</td>  <td 
class="nbHitsCovered">&nbsp;56885</td>  <td class="src"><pre class="src">&nbsp; 
       <span class="keyword">return</span> token;</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;218</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;    }</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;219</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;220</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;    <span 
class="comment">/**</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;221</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span class="comment">     * Parses 
an encapsulated token.</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;222</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span class="comment">     * 
&lt;p/&gt;</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;223</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span class="comment">     * 
Encapsulated tokens are surrounded by the given encapsulating-string. The 
encapsulator itself might be included</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;224</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span class="comment">     * in the 
token using a doubling syntax (as "", '') or using escaping (as in \", \'). 
Whitespaces before and after</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;225</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span class="comment">     * an 
encapsulated token are ignored. The token is finished when one of the following 
conditions become true:</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;226</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span class="comment">     * 
&lt;ul&gt;</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;227</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span class="comment">     * 
&lt;li&gt;an unescaped encapsulator has been reached, and is followed by 
optional whitespace then:&lt;/li&gt;</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;228</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span class="comment">     * 
&lt;ul&gt;</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;229</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span class="comment">     * 
&lt;li&gt;delimiter (TOKEN)&lt;/li&gt;</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;230</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span class="comment">     * 
&lt;li&gt;end of line (EORECORD)&lt;/li&gt;</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;231</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span class="comment">     * 
&lt;/ul&gt;</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;232</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span class="comment">     * 
&lt;li&gt;end of stream has been reached (EOF)&lt;/li&gt; 
&lt;/ul&gt;</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;233</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span class="comment">     
*</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;234</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span class="comment">     * @param 
token</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;235</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span class="comment">     *          
  the current token</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;236</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span class="comment">     * @return 
a valid token object</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;237</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span class="comment">     * @throws 
IOException</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;238</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span class="comment">     *          
   on invalid state: EOF before closing encapsulator or invalid character 
before delimiter or EOL</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;239</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span class="comment">     
*/</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;240</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;    <span 
class="keyword">private</span> Token parseEncapsulatedToken(<span 
class="keyword">final</span> Token token) <span class="keyword">throws</span> 
IOException {</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;241</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;        <span class="comment">// save 
current line number in case needed for IOE</span></pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;242</td>  <td 
class="nbHitsCovered">&nbsp;90997</td>  <td class="src"><pre class="src">&nbsp; 
       <span class="keyword">final</span> <span class="keyword">long</span> 
startLineNumber = getCurrentLineNumber();</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;243</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;        <span 
class="keyword">int</span> c;</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;244</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;        <span 
class="keyword">while</span> (<span class="keyword">true</span>) 
{</pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;245</td>  <td 
class="nbHitsCovered">&nbsp;1012169</td>  <td class="src"><pre 
class="src">&nbsp;            c = reader.read();</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;246</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;</pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;247</td>  <td class="nbHitsCovered"><a 
title="Line 247: Conditional coverage 100% (2/2).">&nbsp;1012169</a></td>  <td 
class="src"><pre class="src">&nbsp;<a title="Line 247: Conditional coverage 
100% (2/2).">            <span class="keyword">if</span> (isEscape(c)) 
{</a></pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;248</td>  <td 
class="nbHitsCovered">&nbsp;4</td>  <td class="src"><pre class="src">&nbsp;     
           <span class="keyword">final</span> <span class="keyword">int</span> 
unescaped = readEscape();</pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;249</td>  <td class="nbHitsUncovered"><a 
title="Line 249: Conditional coverage 50% (1/2).">&nbsp;4</a></td>  <td 
class="src"><pre class="src"><span class="srcUncovered">&nbsp;<a title="Line 
249: Conditional coverage 50% (1/2).">                <span 
class="keyword">if</span> (unescaped == Constants.END_OF_STREAM) { <span 
class="comment">// unexpected char after 
escape</span></a></span></pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;250</td>  <td 
class="nbHitsUncovered">&nbsp;0</td>  <td class="src"><pre class="src"><span 
class="srcUncovered">&nbsp;                    token.content.append((<span 
class="keyword">char</span>) c).append((<span class="keyword">char</span>) 
reader.getLastChar());</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;251</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;                } <span 
class="keyword">else</span> {</pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;252</td>  <td 
class="nbHitsCovered">&nbsp;4</td>  <td class="src"><pre class="src">&nbsp;     
               token.content.append((<span class="keyword">char</span>) 
unescaped);</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;253</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;                }</pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;254</td>  <td class="nbHitsCovered"><a 
title="Line 254: Conditional coverage 100% (2/2).">&nbsp;4</a></td>  <td 
class="src"><pre class="src">&nbsp;<a title="Line 254: Conditional coverage 
100% (2/2).">            } <span class="keyword">else</span> <span 
class="keyword">if</span> (isQuoteChar(c)) {</a></pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;255</td>  <td class="nbHitsCovered"><a 
title="Line 255: Conditional coverage 100% (2/2).">&nbsp;139933</a></td>  <td 
class="src"><pre class="src">&nbsp;<a title="Line 255: Conditional coverage 
100% (2/2).">                <span class="keyword">if</span> 
(isQuoteChar(reader.lookAhead())) {</a></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;256</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;                    <span 
class="comment">// double or escaped encapsulator -&gt; add single encapsulator 
to token</span></pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;257</td>  <td 
class="nbHitsCovered">&nbsp;48936</td>  <td class="src"><pre class="src">&nbsp; 
                   c = reader.read();</pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;258</td>  <td 
class="nbHitsCovered">&nbsp;48936</td>  <td class="src"><pre class="src">&nbsp; 
                   token.content.append((<span class="keyword">char</span>) 
c);</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;259</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;                } <span 
class="keyword">else</span> {</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;260</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;                    <span 
class="comment">// token finish mark (encapsulator) reached: ignore whitespace 
till delimiter</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;261</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;                    <span 
class="keyword">while</span> (<span class="keyword">true</span>) 
{</pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;262</td>  <td 
class="nbHitsCovered">&nbsp;91011</td>  <td class="src"><pre class="src">&nbsp; 
                       c = reader.read();</pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;263</td>  <td class="nbHitsCovered"><a 
title="Line 263: Conditional coverage 100% (2/2).">&nbsp;91011</a></td>  <td 
class="src"><pre class="src">&nbsp;<a title="Line 263: Conditional coverage 
100% (2/2).">                        <span class="keyword">if</span> 
(isDelimiter(c)) {</a></pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;264</td>  <td 
class="nbHitsCovered">&nbsp;46542</td>  <td class="src"><pre class="src">&nbsp; 
                           token.type = TOKEN;</pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;265</td>  <td 
class="nbHitsCovered">&nbsp;46542</td>  <td class="src"><pre class="src">&nbsp; 
                           <span class="keyword">return</span> 
token;</pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;266</td>  <td class="nbHitsCovered"><a 
title="Line 266: Conditional coverage 100% (2/2).">&nbsp;44469</a></td>  <td 
class="src"><pre class="src">&nbsp;<a title="Line 266: Conditional coverage 
100% (2/2).">                        } <span class="keyword">else</span> <span 
class="keyword">if</span> (isEndOfFile(c)) {</a></pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;267</td>  <td 
class="nbHitsCovered">&nbsp;6</td>  <td class="src"><pre class="src">&nbsp;     
                       token.type = EOF;</pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;268</td>  <td 
class="nbHitsCovered">&nbsp;6</td>  <td class="src"><pre class="src">&nbsp;     
                       token.isReady = <span class="keyword">true</span>; <span 
class="comment">// There is data at EOF</span></pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;269</td>  <td 
class="nbHitsCovered">&nbsp;6</td>  <td class="src"><pre class="src">&nbsp;     
                       <span class="keyword">return</span> 
token;</pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;270</td>  <td class="nbHitsCovered"><a 
title="Line 270: Conditional coverage 100% (2/2).">&nbsp;44463</a></td>  <td 
class="src"><pre class="src">&nbsp;<a title="Line 270: Conditional coverage 
100% (2/2).">                        } <span class="keyword">else</span> <span 
class="keyword">if</span> (readEndOfLine(c)) {</a></pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;271</td>  <td 
class="nbHitsCovered">&nbsp;44449</td>  <td class="src"><pre class="src">&nbsp; 
                           token.type = EORECORD;</pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;272</td>  <td 
class="nbHitsCovered">&nbsp;44449</td>  <td class="src"><pre class="src">&nbsp; 
                           <span class="keyword">return</span> 
token;</pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;273</td>  <td class="nbHitsUncovered"><a 
title="Line 273: Conditional coverage 50% (1/2).">&nbsp;14</a></td>  <td 
class="src"><pre class="src"><span class="srcUncovered">&nbsp;<a title="Line 
273: Conditional coverage 50% (1/2).">                        } <span 
class="keyword">else</span> <span class="keyword">if</span> (!isWhitespace(c)) 
{</a></span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;274</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;                            <span 
class="comment">// error invalid char between token and next 
delimiter</span></pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;275</td>  <td 
class="nbHitsUncovered">&nbsp;0</td>  <td class="src"><pre class="src"><span 
class="srcUncovered">&nbsp;                            <span 
class="keyword">throw</span> <span class="keyword">new</span> IOException(<span 
class="string">"(line "</span> + getCurrentLineNumber() +</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;276</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;                                    
<span class="string">") invalid char between encapsulated token and 
delimiter"</span>);</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;277</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;                        
}</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;278</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;                    }</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;279</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;                }</pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;280</td>  <td class="nbHitsUncovered"><a 
title="Line 280: Conditional coverage 50% (1/2).">&nbsp;872232</a></td>  <td 
class="src"><pre class="src"><span class="srcUncovered">&nbsp;<a title="Line 
280: Conditional coverage 50% (1/2).">            } <span 
class="keyword">else</span> <span class="keyword">if</span> (isEndOfFile(c)) 
{</a></span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;281</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;                <span 
class="comment">// error condition (end of file before end of 
token)</span></pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;282</td>  <td 
class="nbHitsUncovered">&nbsp;0</td>  <td class="src"><pre class="src"><span 
class="srcUncovered">&nbsp;                <span class="keyword">throw</span> 
<span class="keyword">new</span> IOException(<span class="string">"(startline 
"</span> + startLineNumber +</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;283</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;                        <span 
class="string">") EOF reached before encapsulated token 
finished"</span>);</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;284</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;            } <span 
class="keyword">else</span> {</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;285</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;                <span 
class="comment">// consume character</span></pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;286</td>  <td 
class="nbHitsCovered">&nbsp;872232</td>  <td class="src"><pre 
class="src">&nbsp;                token.content.append((<span 
class="keyword">char</span>) c);</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;287</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;            }</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;288</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;        }</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;289</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;    }</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;290</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;291</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;    <span 
class="keyword">private</span> <span class="keyword">char</span> 
mapNullToDisabled(<span class="keyword">final</span> Character c) 
{</pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;292</td>  <td class="nbHitsCovered"><a 
title="Line 292: Conditional coverage 100% (2/2).">&nbsp;90345</a></td>  <td 
class="src"><pre class="src">&nbsp;<a title="Line 292: Conditional coverage 
100% (2/2).">        <span class="keyword">return</span> c == <span 
class="keyword">null</span> ? DISABLED : c.charValue();</a></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;293</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;    }</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;294</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;295</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;    <span 
class="comment">/**</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;296</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span class="comment">     * Returns 
the current line number</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;297</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span class="comment">     
*</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;298</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span class="comment">     * @return 
the current line number</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;299</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span class="comment">     
*/</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;300</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;    <span class="keyword">long</span> 
getCurrentLineNumber() {</pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;301</td>  <td 
class="nbHitsCovered">&nbsp;91017</td>  <td class="src"><pre class="src">&nbsp; 
       <span class="keyword">return</span> 
reader.getCurrentLineNumber();</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;302</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;    }</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;303</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;304</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;    <span 
class="comment">/**</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;305</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span class="comment">     * Returns 
the current character position</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;306</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span class="comment">     
*</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;307</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span class="comment">     * @return 
the current character position</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;308</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span class="comment">     
*/</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;309</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;    <span class="keyword">long</span> 
getCharacterPosition() {</pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;310</td>  <td 
class="nbHitsCovered">&nbsp;105699</td>  <td class="src"><pre 
class="src">&nbsp;        <span class="keyword">return</span> 
reader.getPosition();</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;311</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;    }</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;312</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;313</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;    <span class="comment">// TODO 
escape handling needs more work</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;314</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;    <span 
class="comment">/**</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;315</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span class="comment">     * Handle 
an escape sequence.</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;316</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span class="comment">     * The 
current character must be the escape character.</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;317</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span class="comment">     * On 
return, the next character is available by calling {@link 
ExtendedBufferedReader#getLastChar()}</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;318</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span class="comment">     * on the 
input stream.</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;319</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span class="comment">     
*</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;320</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span class="comment">     * @return 
the unescaped character (as an int) or {@link Constants#END_OF_STREAM} if char 
following the escape is</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;321</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span class="comment">     *      
invalid.</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;322</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span class="comment">     * @throws 
IOException if there is a problem reading the stream or the end of stream is 
detected:</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;323</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span class="comment">     *      the 
escape character is not allowed at end of strem</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;324</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span class="comment">     
*/</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;325</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;    <span class="keyword">int</span> 
readEscape() <span class="keyword">throws</span> IOException {</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;326</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;        <span class="comment">// the 
escape char has just been read (normally a backslash)</span></pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;327</td>  <td 
class="nbHitsCovered">&nbsp;96991</td>  <td class="src"><pre class="src">&nbsp; 
       <span class="keyword">final</span> <span class="keyword">int</span> ch = 
reader.read();</pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;328</td>  <td class="nbHitsUncovered"><a 
title="Line 328: Conditional coverage 62% (5/8).">&nbsp;96991</a></td>  <td 
class="src"><pre class="src"><span class="srcUncovered">&nbsp;<a title="Line 
328: Conditional coverage 62% (5/8).">        <span 
class="keyword">switch</span> (ch) {</a></span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;329</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;        <span 
class="keyword">case</span> <span class="string">'r'</span>:</pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;330</td>  <td 
class="nbHitsCovered">&nbsp;24033</td>  <td class="src"><pre class="src">&nbsp; 
           <span class="keyword">return</span> CR;</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;331</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;        <span 
class="keyword">case</span> <span class="string">'n'</span>:</pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;332</td>  <td 
class="nbHitsCovered">&nbsp;24185</td>  <td class="src"><pre class="src">&nbsp; 
           <span class="keyword">return</span> LF;</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;333</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;        <span 
class="keyword">case</span> <span class="string">'t'</span>:</pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;334</td>  <td 
class="nbHitsUncovered">&nbsp;0</td>  <td class="src"><pre class="src"><span 
class="srcUncovered">&nbsp;            <span class="keyword">return</span> 
TAB;</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;335</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;        <span 
class="keyword">case</span> <span class="string">'b'</span>:</pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;336</td>  <td 
class="nbHitsUncovered">&nbsp;0</td>  <td class="src"><pre class="src"><span 
class="srcUncovered">&nbsp;            <span class="keyword">return</span> 
BACKSPACE;</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;337</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;        <span 
class="keyword">case</span> <span class="string">'f'</span>:</pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;338</td>  <td 
class="nbHitsUncovered">&nbsp;0</td>  <td class="src"><pre class="src"><span 
class="srcUncovered">&nbsp;            <span class="keyword">return</span> 
FF;</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;339</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;        <span 
class="keyword">case</span> CR:</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;340</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;        <span 
class="keyword">case</span> LF:</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;341</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;        <span 
class="keyword">case</span> FF: <span class="comment">// TODO is this 
correct?</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;342</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;        <span 
class="keyword">case</span> TAB: <span class="comment">// TODO is this correct? 
Do tabs need to be escaped?</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;343</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;        <span 
class="keyword">case</span> BACKSPACE: <span class="comment">// TODO is this 
correct?</span></pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;344</td>  <td 
class="nbHitsCovered">&nbsp;24459</td>  <td class="src"><pre class="src">&nbsp; 
           <span class="keyword">return</span> ch;</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;345</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;        <span 
class="keyword">case</span> END_OF_STREAM:</pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;346</td>  <td 
class="nbHitsCovered">&nbsp;1</td>  <td class="src"><pre class="src">&nbsp;     
       <span class="keyword">throw</span> <span class="keyword">new</span> 
IOException(<span class="string">"EOF whilst processing escape 
sequence"</span>);</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;347</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;        <span 
class="keyword">default</span>:</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;348</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;            <span class="comment">// 
Now check for meta-characters</span></pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;349</td>  <td class="nbHitsCovered"><a 
title="Line 349: Conditional coverage 100% (2/2).">&nbsp;24313</a></td>  <td 
class="src"><pre class="src">&nbsp;<a title="Line 349: Conditional coverage 
100% (2/2).">            <span class="keyword">if</span> (isMetaChar(ch)) 
{</a></pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;350</td>  <td 
class="nbHitsCovered">&nbsp;24310</td>  <td class="src"><pre class="src">&nbsp; 
               <span class="keyword">return</span> ch;</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;351</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;            }</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;352</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;            <span class="comment">// 
indicate unexpected char - available from 
in.getLastChar()</span></pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;353</td>  <td 
class="nbHitsCovered">&nbsp;3</td>  <td class="src"><pre class="src">&nbsp;     
       <span class="keyword">return</span> END_OF_STREAM;</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;354</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;        }</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;355</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;    }</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;356</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;357</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;    <span class="keyword">void</span> 
trimTrailingSpaces(<span class="keyword">final</span> StringBuilder buffer) 
{</pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;358</td>  <td 
class="nbHitsCovered">&nbsp;77</td>  <td class="src"><pre class="src">&nbsp;    
    <span class="keyword">int</span> length = buffer.length();</pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;359</td>  <td class="nbHitsUncovered"><a 
title="Line 359: Conditional coverage 75% (3/4) [each condition: 50%, 
100%].">&nbsp;96</a></td>  <td class="src"><pre class="src"><span 
class="srcUncovered">&nbsp;<a title="Line 359: Conditional coverage 75% (3/4) 
[each condition: 50%, 100%].">        <span class="keyword">while</span> 
(length &gt; 0 &amp;&amp; Character.isWhitespace(buffer.charAt(length - 1))) 
{</a></span></pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;360</td>  <td 
class="nbHitsCovered">&nbsp;19</td>  <td class="src"><pre class="src">&nbsp;    
        length = length - 1;</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;361</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;        }</pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;362</td>  <td class="nbHitsCovered"><a 
title="Line 362: Conditional coverage 100% (2/2).">&nbsp;77</a></td>  <td 
class="src"><pre class="src">&nbsp;<a title="Line 362: Conditional coverage 
100% (2/2).">        <span class="keyword">if</span> (length != 
buffer.length()) {</a></pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;363</td>  <td 
class="nbHitsCovered">&nbsp;17</td>  <td class="src"><pre class="src">&nbsp;    
        buffer.setLength(length);</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;364</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;        }</pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;365</td>  <td 
class="nbHitsCovered">&nbsp;77</td>  <td class="src"><pre class="src">&nbsp;    
}</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;366</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;367</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;    <span 
class="comment">/**</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;368</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span class="comment">     * Greedily 
accepts \n, \r and \r\n This checker consumes silently the second 
control-character...</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;369</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span class="comment">     
*</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;370</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span class="comment">     * @return 
true if the given or next character is a line-terminator</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;371</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span class="comment">     
*/</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;372</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;    <span 
class="keyword">boolean</span> readEndOfLine(<span class="keyword">int</span> 
ch) <span class="keyword">throws</span> IOException {</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;373</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;        <span class="comment">// 
check if we have \r\n...</span></pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;374</td>  <td class="nbHitsCovered"><a 
title="Line 374: Conditional coverage 100% (4/4) [each condition: 100%, 
100%].">&nbsp;804704</a></td>  <td class="src"><pre class="src">&nbsp;<a 
title="Line 374: Conditional coverage 100% (4/4) [each condition: 100%, 
100%].">        <span class="keyword">if</span> (ch == CR &amp;&amp; 
reader.lookAhead() == LF) {</a></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;375</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;            <span class="comment">// 
note: does not change ch outside of this method!</span></pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;376</td>  <td 
class="nbHitsCovered">&nbsp;50302</td>  <td class="src"><pre class="src">&nbsp; 
           ch = reader.read();</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;377</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;        }</pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;378</td>  <td class="nbHitsCovered"><a 
title="Line 378: Conditional coverage 100% (4/4) [each condition: 100%, 
100%].">&nbsp;804704</a></td>  <td class="src"><pre class="src">&nbsp;<a 
title="Line 378: Conditional coverage 100% (4/4) [each condition: 100%, 
100%].">        <span class="keyword">return</span> ch == LF || ch == 
CR;</a></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;379</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;    }</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;380</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;381</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;    <span 
class="keyword">boolean</span> isClosed() {</pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;382</td>  <td 
class="nbHitsCovered">&nbsp;818</td>  <td class="src"><pre class="src">&nbsp;   
     <span class="keyword">return</span> reader.isClosed();</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;383</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;    }</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;384</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;385</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;    <span 
class="comment">/**</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;386</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span class="comment">     * @return 
true if the given char is a whitespace character</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;387</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span class="comment">     
*/</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;388</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;    <span 
class="keyword">boolean</span> isWhitespace(<span class="keyword">final</span> 
<span class="keyword">int</span> ch) {</pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;389</td>  <td class="nbHitsCovered"><a 
title="Line 389: Conditional coverage 100% (4/4) [each condition: 100%, 
100%].">&nbsp;179</a></td>  <td class="src"><pre class="src">&nbsp;<a 
title="Line 389: Conditional coverage 100% (4/4) [each condition: 100%, 
100%].">        <span class="keyword">return</span> !isDelimiter(ch) &amp;&amp; 
Character.isWhitespace((<span class="keyword">char</span>) 
ch);</a></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;390</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;    }</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;391</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;392</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;    <span 
class="comment">/**</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;393</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span class="comment">     * Checks 
if the current character represents the start of a line: a CR, LF or is at the 
start of the file.</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;394</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span class="comment">     
*</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;395</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span class="comment">     * @param 
ch the character to check</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;396</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span class="comment">     * @return 
true if the character is at the start of a line.</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;397</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span class="comment">     
*/</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;398</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;    <span 
class="keyword">boolean</span> isStartOfLine(<span class="keyword">final</span> 
<span class="keyword">int</span> ch) {</pre></td></tr>
+<tr>  <td class="numLineCover">&nbsp;399</td>  <td class="nbHitsCovered"><a 
title="Line 399: Conditional coverage 100% (6/6) [each condition: 100%, 100%, 
100%].">&nbsp;154198</a></td>  <td class="src"><pre class="src">&nbsp;<a 
title="Line 399: Conditional coverage 100% (6/6) [each condition: 100%, 100%, 
100%].">        <span class="keyword">return</span> ch == LF || ch == CR || ch 
== UNDEFINED;</a></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;400</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;    }</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;401</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;</pre></td></tr>
+<tr>  <td class="numLine">&nbsp;402</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;    <span 
class="comment">/**</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;403</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span class="comment">     * @return 
true if the given character indicates end of file</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;404</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;<span class="comment">     
*/</span></pre></td></tr>
+<tr>  <td class="numLine">&nbsp;405</td>  <td class="nbHits">&nbsp;</td>
+  <td class="src"><pre class="src">&nbsp;    <span 
class="keyword">boolean</span> isEndOfFile(<span class="keyword">final</span> 
<span class="keyword">int</span> ch) {</pre></td></tr>

[... 72 lines stripped ...]

Reply via email to