2013-11-22 17:42:12 -06:00
|
|
|
import java.util.regex.Matcher;
|
|
|
|
import java.util.regex.Pattern;
|
2013-11-09 14:16:22 -06:00
|
|
|
|
|
|
|
public class Regex {
|
|
|
|
private static void expect(boolean v) {
|
|
|
|
if (! v) throw new RuntimeException();
|
|
|
|
}
|
|
|
|
|
|
|
|
private static Matcher getMatcher(String regex, String string) {
|
|
|
|
return Pattern.compile(regex).matcher(string);
|
|
|
|
}
|
|
|
|
|
|
|
|
private static void expectMatch(String regex, String string) {
|
|
|
|
expect(getMatcher(regex, string).matches());
|
|
|
|
}
|
|
|
|
|
|
|
|
private static void expectNoMatch(String regex, String string) {
|
|
|
|
expect(!getMatcher(regex, string).matches());
|
|
|
|
}
|
|
|
|
|
2013-11-11 09:29:24 -06:00
|
|
|
private static void expectGroups(String regex, String string,
|
|
|
|
String... groups) {
|
|
|
|
Matcher matcher = getMatcher(regex, string);
|
|
|
|
expect(matcher.matches());
|
|
|
|
expect(matcher.groupCount() == groups.length);
|
|
|
|
for (int i = 1; i <= groups.length; ++i) {
|
2013-11-10 10:02:18 -06:00
|
|
|
if (groups[i - 1] == null) {
|
|
|
|
expect(matcher.group(i) == null);
|
|
|
|
} else {
|
|
|
|
expect(groups[i - 1].equals(matcher.group(i)));
|
|
|
|
}
|
2013-11-11 09:29:24 -06:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2013-11-13 17:54:47 -06:00
|
|
|
private static void expectFind(String regex, String string,
|
|
|
|
String... matches)
|
|
|
|
{
|
|
|
|
Matcher matcher = getMatcher(regex, string);
|
|
|
|
int i = 0;
|
|
|
|
while (i < matches.length) {
|
|
|
|
expect(matcher.find());
|
|
|
|
expect(matches[i++].equals(matcher.group()));
|
|
|
|
}
|
|
|
|
expect(!matcher.find());
|
|
|
|
}
|
|
|
|
|
2013-11-14 14:46:28 -06:00
|
|
|
private static void expectSplit(String regex, String string,
|
|
|
|
String... list)
|
|
|
|
{
|
|
|
|
String[] array = Pattern.compile(regex).split(string);
|
|
|
|
expect(array.length == list.length);
|
|
|
|
for (int i = 0; i < list.length; ++ i) {
|
|
|
|
expect(list[i].equals(array[i]));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2013-11-09 14:16:22 -06:00
|
|
|
public static void main(String[] args) {
|
|
|
|
expectMatch("a(bb)?a", "abba");
|
|
|
|
expectNoMatch("a(bb)?a", "abbba");
|
|
|
|
expectNoMatch("a(bb)?a", "abbaa");
|
2013-11-11 09:29:24 -06:00
|
|
|
expectGroups("a(a*?)(a?)(a??)(a+)(a*)a", "aaaaaa", "", "a", "", "aaa", "");
|
2013-11-14 11:13:12 -06:00
|
|
|
expectMatch("...", "abc");
|
|
|
|
expectNoMatch(".", "\n");
|
2013-11-10 10:02:18 -06:00
|
|
|
expectGroups("a(bb)*a", "abbbba", "bb");
|
|
|
|
expectGroups("a(bb)?(bb)+a", "abba", null, "bb");
|
2013-11-13 17:54:47 -06:00
|
|
|
expectFind(" +", "Hello , world! ", " ", " ", " ");
|
2013-11-09 15:43:26 -06:00
|
|
|
expectMatch("[0-9A-Fa-f]+", "08ef");
|
|
|
|
expectNoMatch("[0-9A-Fa-f]+", "08@ef");
|
2013-11-12 11:34:30 -06:00
|
|
|
expectGroups("(?:a)", "a");
|
2013-11-11 23:09:25 -06:00
|
|
|
expectGroups("a|(b|c)", "a", (String)null);
|
|
|
|
expectGroups("a|(b|c)", "c", "c");
|
2013-11-12 09:33:45 -06:00
|
|
|
expectGroups("(?=a)a", "a");
|
2013-12-06 10:50:34 -06:00
|
|
|
expectGroups(".*(o)(?<=[A-Z][a-z]{1,4})", "Hello", "o");
|
2013-11-20 09:57:04 -06:00
|
|
|
expectNoMatch("(?!a).", "a");
|
2013-11-12 09:32:20 -06:00
|
|
|
expectMatch("[\\d]", "0");
|
|
|
|
expectMatch("\\0777", "?7");
|
|
|
|
expectMatch("\\a", "\007");
|
|
|
|
expectMatch("\\\\", "\\");
|
|
|
|
expectMatch("\\x4A", "J");
|
|
|
|
expectMatch("\\x61", "a");
|
|
|
|
expectMatch("\\078", "\0078");
|
2013-11-14 14:46:28 -06:00
|
|
|
expectSplit("(?<=\\w)(?=\\W)|(?<=\\W)(?=\\w)", "a + b * x",
|
|
|
|
"a", " + ", "b", " * ", "x");
|
2013-11-12 13:52:20 -06:00
|
|
|
expectMatch("[0-9[def]]", "f");
|
|
|
|
expectNoMatch("[a-z&&[^d-f]]", "f");
|
2013-11-19 22:58:01 -06:00
|
|
|
expectSplit("^H", "Hello\nHobbes!", "", "ello\nHobbes!");
|
|
|
|
expectSplit("o.*?$", "Hello\r\nHobbes!", "Hello\r\nH");
|
2014-04-23 15:22:10 -06:00
|
|
|
try {
|
|
|
|
expectSplit("\\b", "a+ b + c\nd", "", "a", "+ ", "b", " + ", "c", "\n", "d");
|
|
|
|
} catch (RuntimeException e) {
|
|
|
|
// Java 8 changed the semantics of split, so if we're on 8, the
|
|
|
|
// above will fail and this will succeed:
|
|
|
|
expectSplit("\\b", "a+ b + c\nd", "a", "+ ", "b", " + ", "c", "\n", "d");
|
|
|
|
}
|
2013-11-19 22:58:01 -06:00
|
|
|
expectSplit("\\B", "Hi Cal!", "H", "i C", "a", "l!");
|
2013-11-20 10:15:43 -06:00
|
|
|
expectMatch("a{2,5}", "aaaa");
|
|
|
|
expectGroups("a??(a{2,5}?)", "aaaa", "aaaa");
|
|
|
|
expectGroups("a??(a{3}?)", "aaaa", "aaa");
|
|
|
|
expectNoMatch("a(a{3}?)", "aaaaa");
|
|
|
|
expectMatch("a(a{3,}?)", "aaaaa");
|
2013-11-09 14:16:22 -06:00
|
|
|
}
|
|
|
|
}
|