All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.aposin.licensescout.archive.ArchiveIdentifierPattern Maven / Gradle / Ivy

Go to download

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.

There is a newer version: 1.4.0.RC28
Show newest version
/**
 * 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