org.gradle.api.internal.file.pattern.HasSuffixPatternStep Maven / Gradle / Ivy
/*
* Copyright 2014 the original author or authors.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.gradle.api.internal.file.pattern;
/**
* A pattern step for a pattern segment a the common case with a '*' prefix on the pattern. e.g. '*.java'
*/
public class HasSuffixPatternStep implements PatternStep {
private final String suffix;
private final boolean caseSensitive;
private final int suffixLength;
private final int prefixLength;
public HasSuffixPatternStep(String suffix, boolean caseSensitive) {
this(suffix, caseSensitive, 0);
}
// Used by HasPrefixAndSuffixPatternStep to ensure the suffix isn't matching any part of the prefix.
HasSuffixPatternStep(String suffix, boolean caseSensitive, int prefixLength) {
this.suffix = suffix;
suffixLength = suffix.length();
this.caseSensitive = caseSensitive;
this.prefixLength = prefixLength;
}
@Override
public String toString() {
return "{suffix: " + suffix + "}";
}
public boolean matches(String candidate) {
return isLongEnough(candidate) && candidate.regionMatches(!caseSensitive, candidate.length() - suffixLength, suffix, 0, suffixLength);
}
// Confirms there is enough space in candidate to fit both suffix and prefix.
private boolean isLongEnough(String candidate) {
return prefixLength + suffixLength <= candidate.length();
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy