Clover icon

Coverage Report

  1. Project Clover database Mon Nov 18 2024 09:56:54 GMT
  2. Package com.stevesoft.pat

File StrPos.java

 

Coverage histogram

../../../img/srcFileCovDistChart9.png
12% of files have more coverage

Code metrics

20
53
13
1
192
127
28
0.53
4.08
13
2.15

Classes

Class Line # Actions
StrPos 17 53 28
0.837209383.7%
 

Contributing tests

This file is covered by 98 tests. .

Source view

1    //
2    // This software is now distributed according to
3    // the Lesser Gnu Public License. Please see
4    // http://www.gnu.org/copyleft/lesser.txt for
5    // the details.
6    // -- Happy Computing!
7    //
8    package com.stevesoft.pat;
9   
10    /**
11    Shareware: package pat
12    <a href="copyright.html">Copyright 2001, Steven R. Brandt</a>
13    */
14    /**
15    * StrPos is used internally by regex to parse the regular expression.
16    */
 
17    public class StrPos
18    {
19    String s;
20   
21    int pos;
22   
23    /** Return the position in the string pointed to */
 
24  0 toggle public int pos()
25    {
26  0 return pos;
27    }
28   
29    /** This contains the escape character, which is \ by default. */
30    public char esc = Pattern.ESC;
31   
32    char c;
33   
34    /** Returns the current, possibly escaped, character. */
 
35  0 toggle public char thisChar()
36    {
37  0 return c;
38    }
39   
40    boolean dontMatch, eos;
41   
42    /** tell whether we are at end of string */
 
43  0 toggle public boolean eos()
44    {
45  0 return eos;
46    }
47   
48    /** initialize a StrPos from another StrPos. */
 
49  92402 toggle public StrPos(StrPos sp)
50    {
51  92402 dup(sp);
52    }
53   
54    /** copy a StrPos from sp to this. */
 
55  92622 toggle public void dup(StrPos sp)
56    {
57  92622 s = sp.s;
58  92622 pos = sp.pos;
59  92622 c = sp.c;
60  92622 dontMatch = sp.dontMatch;
61  92622 eos = sp.eos;
62    }
63   
64    /**
65    * Initialize a StrPos by giving it a String, and a position within the
66    * String.
67    */
 
68  4506 toggle public StrPos(String s, int pos)
69    {
70  4506 this.s = s;
71  4506 this.pos = pos - 1;
72  4506 inc();
73    }
74   
75    /**
76    * Advance the place where StrPos points within the String. Counts a backslash
77    * as part of the next character.
78    */
 
79  69728 toggle public StrPos inc()
80    {
81  69728 pos++;
82  69728 if (pos >= s.length())
83    {
84  2303 eos = true;
85  2303 return this;
86    }
87  67425 eos = false;
88  67425 c = s.charAt(pos);
89  67425 if (c == esc && pos + 1 < s.length())
90    {
91  7623 pos++;
92  7623 c = s.charAt(pos);
93  7623 if (c != esc)
94    {
95  7599 dontMatch = true;
96    }
97    else
98    {
99  24 dontMatch = false;
100    }
101    }
102    else
103    {
104  59802 dontMatch = false;
105    }
106  67425 return this;
107    }
108   
109    /**
110    * Compare the (possibly escaped) character pointed to by StrPos. Return true
111    * if they are the same, but lways return if character pointed to is escaped.
112    */
 
113  237491 toggle public boolean match(char ch)
114    {
115  237491 if (dontMatch || eos)
116    {
117  28659 return false;
118    }
119  208832 return c == ch;
120    }
121   
122    /** As match, but only matches if the character is escaped. */
 
123  126909 toggle public boolean escMatch(char ch)
124    {
125  126909 if (!dontMatch || eos)
126    {
127  116247 return false;
128    }
129  10662 return c == ch;
130    }
131   
132    /**
133    * Returns true if the current character is escaped (preceeded by "\").
134    */
 
135  0 toggle public boolean escaped()
136    {
137  0 return dontMatch;
138    }
139   
140    /**
141    * Increment the string pointer by each character in
142    *
143    * <pre>
144    * st
145    * </pre>
146    *
147    * that matches a non-escaped character.
148    */
 
149  73982 toggle public boolean incMatch(String st)
150    {
151  73982 StrPos sp = new StrPos(this);
152  73982 int i;
153  88124 for (i = 0; i < st.length(); i++)
154    {
155  88082 if (!sp.match(st.charAt(i)))
156    {
157  73940 return false;
158    }
159  14142 sp.inc();
160    }
161  42 dup(sp);
162  42 return true;
163    }
164   
165    /** Read in an integer. */
 
166  178 toggle public patInt getPatInt()
167    {
168  178 if (incMatch("inf"))
169    {
170  0 return new patInf();
171    }
172  178 int i, cnt = 0;
173  178 StrPos sp = new StrPos(this);
174  371 for (i = 0; !sp.eos && sp.c >= '0' && sp.c <= '9'; i++)
175    {
176  193 cnt = 10 * cnt + sp.c - '0';
177  193 sp.inc();
178    }
179  178 if (i == 0)
180    {
181  0 return null;
182    }
183  178 dup(sp);
184  178 return new patInt(cnt);
185    }
186   
187    /** get the string that we are processing. */
 
188  0 toggle public String getString()
189    {
190  0 return s;
191    }
192    };