corda/classpath/java/util/regex/Matcher.java

120 lines
2.4 KiB
Java
Raw Normal View History

/* Copyright (c) 2008-2013, Avian Contributors
2008-07-13 20:33:51 -06:00
Permission to use, copy, modify, and/or distribute this software
for any purpose with or without fee is hereby granted, provided
that the above copyright notice and this permission notice appear
in all copies.
There is NO WARRANTY for this software. See license.txt for
details. */
package java.util.regex;
/**
* This is a work in progress.
2008-07-13 20:33:51 -06:00
*
* @author zsombor and others
2008-07-13 20:33:51 -06:00
*/
public abstract class Matcher {
protected CharSequence input;
protected int start;
protected int end;
public Matcher(CharSequence input) {
reset(input);
}
2008-07-13 20:33:51 -06:00
public abstract boolean matches();
public boolean find() {
return find(end);
2008-07-13 20:33:51 -06:00
}
public abstract boolean find(int start);
2008-07-13 20:33:51 -06:00
public Matcher reset() {
return reset(input);
2008-07-13 20:33:51 -06:00
}
public Matcher reset(CharSequence input) {
this.input = input;
start = 0;
end = 0;
return this;
2008-07-13 20:33:51 -06:00
}
public String replaceAll(String replacement) {
return replace(replacement, Integer.MAX_VALUE);
2008-07-13 20:33:51 -06:00
}
public String replaceFirst(String replacement) {
return replace(replacement, 1);
}
protected String replace(String replacement, int limit) {
reset();
StringBuilder sb = null;
int index = 0;
int count = 0;
while (count < limit && index < input.length()) {
if (find(index)) {
if (sb == null) {
sb = new StringBuilder();
}
if (start > index) {
sb.append(input.subSequence(index, start));
}
sb.append(replacement);
index = end;
++ count;
} else if (index == 0) {
return input.toString();
} else {
break;
}
}
if (index < input.length()) {
sb.append(input.subSequence(index, input.length()));
}
return sb.toString();
2008-07-13 20:33:51 -06:00
}
public int start() {
return start;
}
2008-07-13 20:33:51 -06:00
public int end() {
return end;
2008-07-13 20:33:51 -06:00
}
public String group() {
return input.subSequence(start, end).toString();
}
public int start(int group) {
if (group == 0) {
return start();
}
throw new UnsupportedOperationException();
}
public int end(int group) {
if (group == 0) {
return end();
}
throw new UnsupportedOperationException();
2008-07-13 20:33:51 -06:00
}
public String group(int group) {
if (group == 0) {
return group();
}
throw new UnsupportedOperationException();
}
public int groupCount() {
return 0;
2008-07-13 20:33:51 -06:00
}
}