X-Git-Url: http://www2.svjatoslav.eu/gitweb/?p=svjatoslav_commons.git;a=blobdiff_plain;f=src%2Fmain%2Fjava%2Feu%2Fsvjatoslav%2Fcommons%2Fstring%2Ftokenizer%2FTerminator.java;h=a298538fd28c7fbc6b5c0c0ea77a6ed394760c01;hp=2d0fd456186c3322b1504bec6896e4d6cc918daa;hb=798a165906826270924f0d5d58cfa04cf6bdc113;hpb=0b3d733f44e95ee093985531072a1f8965f7c09a diff --git a/src/main/java/eu/svjatoslav/commons/string/tokenizer/Terminator.java b/src/main/java/eu/svjatoslav/commons/string/tokenizer/Terminator.java index 2d0fd45..a298538 100755 --- a/src/main/java/eu/svjatoslav/commons/string/tokenizer/Terminator.java +++ b/src/main/java/eu/svjatoslav/commons/string/tokenizer/Terminator.java @@ -11,12 +11,13 @@ package eu.svjatoslav.commons.string.tokenizer; public class Terminator { - final String startSequence; - String endSequence; - TerminationStrategy termination; + public final String startSequence; + public final String endSequence; + public final TerminationStrategy termination; - public Terminator(final String startPattern, TerminationStrategy termination) { - startSequence = startPattern; + public Terminator(final String startSequence, TerminationStrategy termination) { + this.startSequence = startSequence; + this.endSequence = null; this.termination = termination; } @@ -26,8 +27,30 @@ public class Terminator { this.termination = termination; } - enum TerminationStrategy { + public boolean matches(String source, int index) { + // boundary check + if (source.length() < (index + startSequence.length())) + return false; + + // match check + for (int i = 0; i < startSequence.length(); i++) + if (startSequence.charAt(i) != source.charAt(index + i)) + return false; + + return true; + } + + public enum TerminationStrategy { PRESERVE, - DROP; + DROP + } + + @Override + public String toString() { + return "Terminator{" + + "startSequence='" + startSequence + '\'' + + ", endSequence='" + endSequence + '\'' + + ", termination=" + termination + + '}'; } }