org.bitbucket.bradleysmithllc.etlunit.feature.database.DDLInstrumentationExpression Maven / Gradle / Ivy
package org.bitbucket.bradleysmithllc.etlunit.feature.database;
/*
Regular expression class compiled by the Regular Expression Compiler 1.6.11
*/
import java.util.Map;
import java.util.HashMap;
import java.util.regex.Pattern;
import java.util.regex.Matcher;
public final class DDLInstrumentationExpression
{
public static final String PATTERN_RAW_TEXT = "(?'newLine'\\r\\n|\\n)|(/\\*\\*[\\s]*DDL Source \\[(?'ref'[^:]+):(?'lineNo'\\d+)\\][\\s]*\\*\\*/)";
public static final String PATTERN_TEXT;
public static final Pattern pattern;
private static final Map groupOffsets = new HashMap();
private final Matcher matcher;
private final CharSequence matchText;
public static interface RegExpIterator
{
String replaceMatch(DDLInstrumentationExpression e);
}
static
{
PATTERN_TEXT = PATTERN_RAW_TEXT.replaceAll("\\(\\?'[^']+'", "(");
Pattern cpattern = Pattern.compile("(\\\\)?\\((\\?'([^']+)')?");
Matcher matcher = cpattern.matcher(PATTERN_RAW_TEXT);
int groupCount = 1;
while (matcher.find())
{
if (matcher.group(1) != null)
{
continue;
}
String groupName = matcher.group(3);
if (groupName != null)
{
groupOffsets.put(groupName, new Integer(groupCount));
}
groupCount++;
}
pattern = Pattern.compile(PATTERN_TEXT, Pattern.CASE_INSENSITIVE | Pattern.MULTILINE);
}
private DDLInstrumentationExpression(Matcher pMatcher, CharSequence ch)
{
matcher = pMatcher;
matchText = ch;
}
public DDLInstrumentationExpression(CharSequence ch)
{
this(pattern.matcher(ch), ch);
}
public static DDLInstrumentationExpression match(CharSequence pText)
{
return new DDLInstrumentationExpression(pText);
}
public int end()
{
return matcher.end();
}
public int end(int group)
{
return matcher.end(group);
}
public int start()
{
return matcher.start();
}
public int start(int group)
{
return matcher.start(group);
}
public String replaceAll(String replacement)
{
return matcher.replaceAll(replacement);
}
public String replaceAll(RegExpIterator it)
{
String match = matchText.toString();
String str = "";
int end = -1;
while (hasNext())
{
str += match.substring(end == -1 ? 0 : end, start());
str += it.replaceMatch(this);
end = end();
}
str += match.substring(end == -1 ? 0 : end, match.length());
return str;
}
public boolean matches()
{
return matcher.matches();
}
public boolean hasNext()
{
return matcher.find();
}
public int groupCount()
{
return matcher.groupCount();
}
public String group()
{
return matcher.group();
}
public String group(int i)
{
return matcher.group(i);
}
public DDLInstrumentationExpression resetMatch(CharSequence seq)
{
return match(seq);
}
public String group(String name)
{
return matcher.group(groupOffsets.get(name).intValue());
}
private static String scope(String text, String name)
{
return text.replaceAll("(\\(\\?')(\\w+')", "$1" + name + ".$2");
}
public boolean hasNewLine()
{
return group("newLine") != null;
}
public String getNewLine()
{
if (!hasNewLine())
{
throw new IllegalArgumentException("Property not defined: NewLine");
}
return group("newLine");
}
public boolean hasRef()
{
return group("ref") != null;
}
public String getRef()
{
if (!hasRef())
{
throw new IllegalArgumentException("Property not defined: Ref");
}
return group("ref");
}
public boolean hasLineNo()
{
return group("lineNo") != null;
}
public int getLineNo()
{
if (!hasLineNo())
{
throw new IllegalArgumentException("Property not defined: LineNo");
}
return Integer.parseInt(group("lineNo"));
}
public String toString()
{
return "{DDLInstrumentationExpression, matchText='" + matchText + "'}[" + "(newLine)=" + (hasNewLine() ? getNewLine() : "null") + ", (ref)=" + (hasRef() ? getRef() : "null") + ", (lineNo)=" + (hasLineNo() ? getLineNo() : "null") + "]";
}
public static void main(String [] argv)
{
System.out.println(PATTERN_TEXT);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy