com.thaiopensource.xml.dtd.parse.ReplacementTextBuffer Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of trang Show documentation
Show all versions of trang Show documentation
Trang, a multi-format schema converter based on RELAX NG.
The newest version!
package com.thaiopensource.xml.dtd.parse;
import com.thaiopensource.xml.tok.Token;
class ReplacementTextBuffer {
private static final int INIT_SIZE = 64;
private char[] buf = new char[INIT_SIZE];
private int len;
private boolean mustReparse = false;
private Entity.Reference[] refs = new Entity.Reference[2];
int nRefs;
public void clear() {
len = 0;
mustReparse = false;
nRefs = 0;
}
public void setMustReparse() {
mustReparse = true;
}
public boolean getMustReparse() {
return mustReparse;
}
public void appendReplacementText(Entity entity) {
appendEntityReference(new Entity.Reference(entity, len, len + entity.text.length));
append(entity.text, 0, entity.text.length);
}
private void appendEntityReference(Entity.Reference r) {
if (nRefs == refs.length) {
Entity.Reference[] tem = refs;
refs = new Entity.Reference[tem.length << 1];
System.arraycopy(tem, 0, refs, 0, tem.length);
}
refs[nRefs++] = r;
}
public Entity.Reference[] getReferences() {
if (nRefs == 0)
return null;
Entity.Reference[] r = new Entity.Reference[nRefs];
System.arraycopy(refs, 0, r, 0, nRefs);
return r;
}
public void append(char c) {
need(1);
buf[len++] = c;
}
public void appendRefCharPair(Token t) {
need(2);
t.getRefCharPair(buf, len);
len += 2;
}
public void append(char[] cbuf, int start, int end) {
need(end - start);
for (int i = start; i < end; i++)
buf[len++] = cbuf[i];
}
private void need(int n) {
if (len + n <= buf.length)
return;
char[] tem = buf;
if (n > tem.length)
buf = new char[n * 2];
else
buf = new char[tem.length << 1];
System.arraycopy(tem, 0, buf, 0, tem.length);
}
public char[] getChars() {
char[] text = new char[len];
System.arraycopy(buf, 0, text, 0, len);
return text;
}
public String toString() {
return new String(buf, 0, len);
}
public int length() {
return len;
}
public char charAt(int i) {
if (i >= len)
throw new IndexOutOfBoundsException();
return buf[i];
}
public void chop() {
--len;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy