org.aposin.licensescout.archive.ArchiveIdentifierPattern Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of licensescout-maven-plugin Show documentation
Show all versions of licensescout-maven-plugin Show documentation
Maven plug-in using the LicenseScout Core for standard Maven builds. Can write reports as CSV, Text or HTML using configurable templates and can write results to a database.
/**
* Copyright 2019 Association for the promotion of open-source insurance software and for the establishment of open interface standards in the insurance industry (Verein zur Förderung quelloffener Versicherungssoftware und Etablierung offener Schnittstellenstandards in der Versicherungsbranche)
*
* 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.aposin.licensescout.archive;
import java.util.regex.Pattern;
/**
* Identifier for an archive bases on a regular expression for the name.
*
* Always uses {@link NameMatchingType#PATTERN} to designate using regular expressions. {@link PatternType} that determines if the regex is applied on either the archive name or the archive path
* is passed to the constructor.
*
* @see ArchiveIdentifierVersion
* @see PatternType
*
*/
public class ArchiveIdentifierPattern extends ArchiveIdentifier {
private final PatternType patternType;
private final Pattern pattern;
/**
* Constructor.
*
* @param archiveType type of the archive
* @param patternType
* @param regex the regular expression
*/
public ArchiveIdentifierPattern(final ArchiveType archiveType, final PatternType patternType, final String regex) {
super(archiveType, NameMatchingType.PATTERN, regex);
this.patternType = patternType;
pattern = Pattern.compile(regex);
}
/**
* @return the patternType
*/
public final PatternType getPatternType() {
return patternType;
}
/**
* @return the pattern
*/
public final Pattern getPattern() {
return pattern;
}
/**
* {@inheritDoc}
*/
@Override
public int hashCode() {
final int prime = 31;
int result = 1;
result = prime * result + ((getArchiveType() == null) ? 0 : getArchiveType().hashCode());
result = prime * result + ((getName() == null) ? 0 : getName().hashCode());
return result;
}
/**
* {@inheritDoc}
*/
@Override
public boolean equals(Object obj) {
if (this == obj) {
return true;
}
if (obj == null) {
return false;
}
if (getClass() != obj.getClass()) {
return false;
}
ArchiveIdentifierPattern other = (ArchiveIdentifierPattern) obj;
if (getArchiveType() != other.getArchiveType()) {
return false;
}
if (getName() == null) {
if (other.getName() != null) {
return false;
}
} else if (!getName().equals(other.getName())) {
return false;
}
return true;
}
}
© 2015 - 2024 Weber Informatics LLC | Privacy Policy