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=39718cdbe39e6192a33258bd8c3ac83435948017;hb=798a165906826270924f0d5d58cfa04cf6bdc113;hpb=6fe5e2d632264f5cda3995e761342713f16d95f3 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 39718cd..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; } + 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 } + + @Override + public String toString() { + return "Terminator{" + + "startSequence='" + startSequence + '\'' + + ", endSequence='" + endSequence + '\'' + + ", termination=" + termination + + '}'; + } }