public class SimpleCharStream
{
- public static final boolean staticFlag = true;
- static int bufsize;
- static int available;
- static int tokenBegin;
- static public int bufpos = -1;
+ public static final boolean staticFlag = false;
+ int bufsize;
+ int available;
+ int tokenBegin;
+ public int bufpos = -1;
- //Added by Matthieu Casanova
- public static int position = 0;
+ protected int beginOffset, endOffset;
- public static int beginOffset, endOffset;
+ protected int bufline[];
+ protected int bufcolumn[];
- static protected int bufline[];
- static protected int bufcolumn[];
+ protected int column = 0;
+ protected int line = 1;
- static protected int column = 0;
- static protected int line = 1;
+ protected boolean prevCharIsCR = false;
+ protected boolean prevCharIsLF = false;
- static protected boolean prevCharIsCR = false;
- static protected boolean prevCharIsLF = false;
+ protected java.io.Reader inputStream;
- static protected java.io.Reader inputStream;
- static protected StringBuffer currentBuffer = new StringBuffer();
+ protected char[] buffer;
+ protected int maxNextCharInd = 0;
+ protected int inBuf = 0;
+ protected StringBuffer currentBuffer = new StringBuffer();
- static protected char[] buffer;
- static protected int maxNextCharInd = 0;
- static protected int inBuf = 0;
-
- static protected void ExpandBuff(boolean wrapAround)
+ protected void ExpandBuff(boolean wrapAround)
{
char[] newbuffer = new char[bufsize + 2048];
int newbufline[] = new int[bufsize + 2048];
tokenBegin = 0;
}
- static protected void FillBuff() throws java.io.IOException
+ protected void FillBuff() throws java.io.IOException
{
if (maxNextCharInd == available)
{
}
}
- static public char BeginToken() throws java.io.IOException
+ public char BeginToken() throws java.io.IOException
{
beginOffset = endOffset;
tokenBegin = -1;
return c;
}
- static protected void UpdateLineColumn(char c)
+ protected void UpdateLineColumn(char c)
{
column++;
bufline[bufpos] = line;
bufcolumn[bufpos] = column;
-
}
- static public char readChar() throws java.io.IOException
+ public char readChar() throws java.io.IOException
{
endOffset++;
if (inBuf > 0)
return buffer[bufpos];
}
- if (++bufpos >= maxNextCharInd) {
- FillBuff();
- }
+ if (++bufpos >= maxNextCharInd)
+ FillBuff();
char c = buffer[bufpos];
}
/**
- * @deprecated
+ * @deprecated
* @see #getEndColumn
*/
- static public int getColumn() {
+ public int getColumn() {
return bufcolumn[bufpos];
}
/**
- * @deprecated
+ * @deprecated
* @see #getEndLine
*/
- static public int getLine() {
+ public int getLine() {
return bufline[bufpos];
}
- static public int getEndColumn() {
+ public int getEndColumn() {
return bufcolumn[bufpos];
}
- static public int getEndLine() {
+ public int getEndLine() {
return bufline[bufpos];
}
- static public int getBeginColumn() {
+ public int getBeginColumn() {
return bufcolumn[tokenBegin];
}
- static public int getBeginLine() {
+ public int getBeginLine() {
return bufline[tokenBegin];
}
- static public void backup(int amount) {
+ public void backup(int amount) {
+
endOffset -= amount;
inBuf += amount;
if ((bufpos -= amount) < 0)
public SimpleCharStream(java.io.Reader dstream, int startline,
int startcolumn, int buffersize)
{
- if (inputStream != null)
- throw new Error("\n ERROR: Second call to the constructor of a static SimpleCharStream. You must\n" +
- " either use ReInit() or set the JavaCC option STATIC to false\n" +
- " during the generation of this class.");
inputStream = dstream;
- currentBuffer = new StringBuffer();
+ currentBuffer = new StringBuffer();
line = startline;
column = startcolumn - 1;
bufcolumn = new int[buffersize];
beginOffset = 0;
endOffset = 0;
-
}
public SimpleCharStream(java.io.Reader dstream, int startline,
{
ReInit(dstream, startline, startcolumn, 4096);
}
- static public String GetImage()
+ public String GetImage()
{
if (bufpos >= tokenBegin)
return new String(buffer, tokenBegin, bufpos - tokenBegin + 1);
new String(buffer, 0, bufpos + 1);
}
- static public char[] GetSuffix(int len)
+ public char[] GetSuffix(int len)
{
char[] ret = new char[len];
return ret;
}
- static public void Done()
+ public void Done()
{
buffer = null;
bufline = null;
bufcolumn = null;
-
}
/**
* Method to adjust line and column numbers for the start of a token.<BR>
*/
- static public void adjustBeginLineColumn(int newLine, int newCol)
+ public void adjustBeginLineColumn(int newLine, int newCol)
{
int start = tokenBegin;
int len;
bufcolumn[j] = newCol + columnDiff;
columnDiff = nextColDiff;
i++;
- }
+ }
if (i < len)
{
while (i++ < len)
{
- if (bufline[j = start % bufsize] != bufline[++start % bufsize]) {
+ if (bufline[j = start % bufsize] != bufline[++start % bufsize])
bufline[j] = newLine++;
- } else {
+ else
bufline[j] = newLine;
- }
}
}
column = bufcolumn[j];
}
+ public StringBuffer getCurrentBuffer() {
+ return currentBuffer;
+ }
+
+ //Added by Matthieu Casanova
+ public int position = 0;
/**
* @deprecated
* @return
*/
- public static int getPosition() {
+ public int getPosition() {
return position + bufpos;
}
+
+ public int getBeginOffset() {
+ return beginOffset;
+ }
+
+ public int getEndOffset() {
+ return endOffset;
+ }
}