2007-07-04 16:27:08 -06:00
|
|
|
package java.lang;
|
|
|
|
|
|
|
|
public class StringBuilder {
|
2007-08-30 17:31:32 -06:00
|
|
|
private static final int BufferSize = 32;
|
|
|
|
|
2007-07-04 16:27:08 -06:00
|
|
|
private Cell chain;
|
|
|
|
private int length;
|
2007-08-14 19:14:55 -06:00
|
|
|
private char[] buffer;
|
|
|
|
private int position;
|
2007-07-04 16:27:08 -06:00
|
|
|
|
2007-08-30 17:31:32 -06:00
|
|
|
public StringBuilder(String s) {
|
|
|
|
append(s);
|
|
|
|
}
|
|
|
|
|
2007-07-29 17:32:23 -06:00
|
|
|
public StringBuilder(int capacity) { }
|
|
|
|
|
|
|
|
public StringBuilder() {
|
|
|
|
this(0);
|
|
|
|
}
|
|
|
|
|
2007-08-14 19:14:55 -06:00
|
|
|
private void flush() {
|
|
|
|
if (position > 0) {
|
|
|
|
char[] b = buffer;
|
|
|
|
int p = position;
|
|
|
|
buffer = null;
|
|
|
|
position = 0;
|
|
|
|
append(new String(b, 0, p, false));
|
|
|
|
length -= p;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2007-07-04 16:27:08 -06:00
|
|
|
public StringBuilder append(String s) {
|
2007-08-14 19:14:55 -06:00
|
|
|
if (s == null) {
|
|
|
|
return append("null");
|
|
|
|
} else {
|
|
|
|
if (s.length() > 0) {
|
2007-08-30 17:31:32 -06:00
|
|
|
if (buffer != null && s.length() <= buffer.length - position) {
|
|
|
|
s.getChars(0, s.length(), buffer, position);
|
|
|
|
position += s.length();
|
|
|
|
} else {
|
|
|
|
flush();
|
|
|
|
chain = new Cell(s, chain);
|
|
|
|
}
|
2007-08-14 19:14:55 -06:00
|
|
|
length += s.length();
|
|
|
|
}
|
|
|
|
return this;
|
2007-07-28 20:15:45 -06:00
|
|
|
}
|
2007-07-04 16:27:08 -06:00
|
|
|
}
|
|
|
|
|
2007-07-28 20:15:45 -06:00
|
|
|
public StringBuilder append(char[] b, int offset, int length) {
|
|
|
|
return append(new String(b, offset, length));
|
|
|
|
}
|
|
|
|
|
2007-07-19 21:18:25 -06:00
|
|
|
public StringBuilder append(Object o) {
|
|
|
|
return append(o == null ? "null" : o.toString());
|
|
|
|
}
|
|
|
|
|
2007-08-14 19:14:55 -06:00
|
|
|
public StringBuilder append(char v) {
|
|
|
|
if (buffer == null) {
|
2007-08-30 17:31:32 -06:00
|
|
|
buffer = new char[BufferSize];
|
2007-08-14 19:14:55 -06:00
|
|
|
} else if (position >= buffer.length) {
|
|
|
|
flush();
|
2007-08-30 17:31:32 -06:00
|
|
|
buffer = new char[BufferSize];
|
2007-08-14 19:14:55 -06:00
|
|
|
}
|
|
|
|
|
|
|
|
buffer[position++] = v;
|
|
|
|
++ length;
|
|
|
|
|
|
|
|
return this;
|
|
|
|
}
|
|
|
|
|
2007-08-23 18:20:42 -06:00
|
|
|
public StringBuilder append(boolean v) {
|
|
|
|
return append(String.valueOf(v));
|
|
|
|
}
|
|
|
|
|
2007-07-04 16:27:08 -06:00
|
|
|
public StringBuilder append(int v) {
|
2007-07-19 21:18:25 -06:00
|
|
|
return append(String.valueOf(v));
|
2007-07-04 16:27:08 -06:00
|
|
|
}
|
|
|
|
|
|
|
|
public StringBuilder append(long v) {
|
2007-07-19 21:18:25 -06:00
|
|
|
return append(String.valueOf(v));
|
2007-07-04 16:27:08 -06:00
|
|
|
}
|
|
|
|
|
2007-10-02 08:58:35 -06:00
|
|
|
public StringBuilder append(float v) {
|
|
|
|
return append(String.valueOf(v));
|
|
|
|
}
|
|
|
|
|
|
|
|
public StringBuilder append(double v) {
|
|
|
|
return append(String.valueOf(v));
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2007-08-30 17:31:32 -06:00
|
|
|
public char charAt(int i) {
|
|
|
|
if (i < 0 || i >= length) {
|
|
|
|
throw new IndexOutOfBoundsException();
|
|
|
|
}
|
|
|
|
|
|
|
|
flush();
|
|
|
|
|
|
|
|
int index = length;
|
|
|
|
-- length;
|
|
|
|
Cell p = null;
|
|
|
|
for (Cell c = chain; c != null; c = c.next) {
|
|
|
|
int start = index - c.value.length();
|
|
|
|
index = start;
|
|
|
|
|
|
|
|
if (i >= start) {
|
|
|
|
return c.value.charAt(i - start);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
throw new RuntimeException();
|
|
|
|
}
|
|
|
|
|
|
|
|
public StringBuilder insert(int i, String s) {
|
|
|
|
if (i < 0 || i >= length) {
|
|
|
|
throw new IndexOutOfBoundsException();
|
|
|
|
}
|
|
|
|
|
|
|
|
if (i == length) {
|
|
|
|
append(s);
|
|
|
|
} else {
|
|
|
|
flush();
|
|
|
|
|
|
|
|
int index = length;
|
|
|
|
-- length;
|
|
|
|
for (Cell c = chain; c != null; c = c.next) {
|
|
|
|
int start = index - c.value.length();
|
|
|
|
index = start;
|
|
|
|
|
|
|
|
if (i >= start) {
|
|
|
|
if (i == start) {
|
|
|
|
c.next = new Cell(s, c.next);
|
|
|
|
} else {
|
|
|
|
String v = c.value;
|
|
|
|
c.value = v.substring(i - start, v.length());
|
|
|
|
c.next = new Cell(s, new Cell(v.substring(0, i - start), c.next));
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return this;
|
|
|
|
}
|
|
|
|
|
2007-09-12 18:21:37 -06:00
|
|
|
public StringBuilder insert(int i, char c) {
|
|
|
|
return insert(i, new String(new char[] { c }, 0, 1, false));
|
|
|
|
}
|
|
|
|
|
2007-10-29 15:07:36 -06:00
|
|
|
public StringBuilder delete(int start, int end) {
|
2007-10-29 15:40:05 -06:00
|
|
|
if (start >= end) {
|
|
|
|
return this;
|
2007-10-29 15:07:36 -06:00
|
|
|
}
|
|
|
|
|
2007-10-29 15:40:05 -06:00
|
|
|
if (start < 0 || end > length) {
|
2007-07-28 20:15:45 -06:00
|
|
|
throw new IndexOutOfBoundsException();
|
|
|
|
}
|
|
|
|
|
2007-08-14 19:14:55 -06:00
|
|
|
flush();
|
|
|
|
|
2007-07-28 20:15:45 -06:00
|
|
|
int index = length;
|
|
|
|
-- length;
|
|
|
|
Cell p = null;
|
|
|
|
for (Cell c = chain; c != null; c = c.next) {
|
2007-10-29 15:40:05 -06:00
|
|
|
int e = index;
|
|
|
|
int s = index - c.value.length();
|
|
|
|
index = s;
|
2007-07-28 20:15:45 -06:00
|
|
|
|
2007-10-29 15:40:05 -06:00
|
|
|
if (end >= e) {
|
|
|
|
if (start <= s) {
|
2007-07-28 20:15:45 -06:00
|
|
|
if (p == null) {
|
|
|
|
chain = c.next;
|
|
|
|
} else {
|
|
|
|
p.next = c.next;
|
2007-10-29 15:40:05 -06:00
|
|
|
}
|
2007-07-28 20:15:45 -06:00
|
|
|
} else {
|
2007-10-29 15:40:05 -06:00
|
|
|
c.value = c.value.substring(0, start - s);
|
|
|
|
break;
|
2007-07-28 20:15:45 -06:00
|
|
|
}
|
2007-10-29 15:40:05 -06:00
|
|
|
} else {
|
|
|
|
if (start <= s) {
|
|
|
|
c.value = c.value.substring(end - s, e - s);
|
|
|
|
} else {
|
|
|
|
String v = c.value;
|
|
|
|
c.value = v.substring(end - s, e - s);
|
|
|
|
c.next = new Cell(v.substring(0, start - s), c.next);
|
|
|
|
break;
|
|
|
|
}
|
2007-07-28 20:15:45 -06:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return this;
|
|
|
|
}
|
|
|
|
|
2007-10-29 15:40:05 -06:00
|
|
|
public StringBuilder deleteCharAt(int i) {
|
|
|
|
return delete(i, i + 1);
|
|
|
|
}
|
|
|
|
|
2007-10-29 15:07:36 -06:00
|
|
|
public StringBuilder replace(int start, int end, String str) {
|
|
|
|
delete(start, end);
|
|
|
|
insert(start, str);
|
|
|
|
return this;
|
|
|
|
}
|
|
|
|
|
2007-07-28 19:29:01 -06:00
|
|
|
public int length() {
|
|
|
|
return length;
|
|
|
|
}
|
|
|
|
|
2007-07-28 20:15:45 -06:00
|
|
|
public void setLength(int v) {
|
|
|
|
if (v < 0) {
|
|
|
|
throw new IndexOutOfBoundsException();
|
|
|
|
}
|
|
|
|
|
|
|
|
if (v == 0) {
|
|
|
|
length = 0;
|
|
|
|
chain = null;
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2007-08-14 19:14:55 -06:00
|
|
|
flush();
|
|
|
|
|
2007-07-28 20:15:45 -06:00
|
|
|
int index = length;
|
|
|
|
length = v;
|
|
|
|
for (Cell c = chain; c != null; c = c.next) {
|
|
|
|
int start = index - c.value.length();
|
|
|
|
|
|
|
|
if (v > start) {
|
|
|
|
if (v < index) {
|
|
|
|
c.value = c.value.substring(0, v - start);
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
chain = c.next;
|
|
|
|
index = start;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2007-07-28 19:29:01 -06:00
|
|
|
public void getChars(int srcOffset, int srcLength, char[] dst, int dstOffset)
|
|
|
|
{
|
2007-07-28 20:15:45 -06:00
|
|
|
if (srcOffset < 0 || srcOffset + srcLength > length) {
|
2007-07-28 19:29:01 -06:00
|
|
|
throw new IndexOutOfBoundsException();
|
|
|
|
}
|
|
|
|
|
2007-08-14 19:14:55 -06:00
|
|
|
flush();
|
|
|
|
|
2007-07-04 16:27:08 -06:00
|
|
|
int index = length;
|
|
|
|
for (Cell c = chain; c != null; c = c.next) {
|
2007-07-28 19:29:01 -06:00
|
|
|
int start = index - c.value.length();
|
|
|
|
int end = index;
|
|
|
|
index = start;
|
|
|
|
|
|
|
|
if (start < srcOffset) {
|
|
|
|
start = srcOffset;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (end > srcOffset + srcLength) {
|
|
|
|
end = srcOffset + srcLength;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (start < end) {
|
|
|
|
c.value.getChars(start - index, end - start,
|
|
|
|
dst, dstOffset + (start - srcOffset));
|
|
|
|
}
|
2007-08-14 19:14:55 -06:00
|
|
|
}
|
2007-07-28 19:29:01 -06:00
|
|
|
}
|
|
|
|
|
|
|
|
public String toString() {
|
|
|
|
char[] array = new char[length];
|
|
|
|
getChars(0, length, array, 0);
|
2007-07-10 19:38:06 -06:00
|
|
|
return new String(array, 0, length, false);
|
2007-07-04 16:27:08 -06:00
|
|
|
}
|
|
|
|
|
|
|
|
private static class Cell {
|
2007-07-28 20:15:45 -06:00
|
|
|
public String value;
|
|
|
|
public Cell next;
|
2007-07-04 16:27:08 -06:00
|
|
|
|
|
|
|
public Cell(String value, Cell next) {
|
|
|
|
this.value = value;
|
|
|
|
this.next = next;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|