com.github.maven_nar.AttachedNarArtifact.java Source code

Java tutorial

Introduction

Here is the source code for com.github.maven_nar.AttachedNarArtifact.java

Source

/*
 * #%L
 * Native ARchive plugin for Maven
 * %%
 * Copyright (C) 2002 - 2014 NAR Maven Plugin developers.
 * %%
 * 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.
 * #L%
 */
package com.github.maven_nar;

import java.io.File;

import org.apache.maven.artifact.Artifact;
import org.apache.maven.artifact.DefaultArtifact;
import org.apache.maven.artifact.handler.ArtifactHandler;
import org.apache.maven.artifact.versioning.InvalidVersionSpecificationException;
import org.apache.maven.artifact.versioning.VersionRange;

/**
 * NarArtifact with its own type, classifier and artifactHandler.
 *
 * @author Mark Donszelmann
 */
public class AttachedNarArtifact extends DefaultArtifact {
    private class Handler implements ArtifactHandler {
        private final String classifier;

        Handler(final String classifier) {
            this.classifier = classifier;
        }

        @Override
        public String getClassifier() {
            return this.classifier;
        }

        @Override
        public String getDirectory() {
            return "nars";
        }

        @Override
        public String getExtension() {
            return "nar";
        }

        @Override
        public String getLanguage() {
            return "native";
        }

        @Override
        public String getPackaging() {
            return "nar";
        }

        @Override
        public boolean isAddedToClasspath() {
            return true;
        }

        @Override
        public boolean isIncludesDependencies() {
            return false;
        }
    }

    // NOTE: not used
    public AttachedNarArtifact(final Artifact parent, final String type, final String classifier) {
        super(parent.getGroupId(), parent.getArtifactId(), parent.getVersionRange(), parent.getScope(), type,
                classifier, null, parent.isOptional());
        setArtifactHandler(new Handler(classifier));
    }

    public AttachedNarArtifact(final String groupId, final String artifactId, final String version,
            final String scope, final String type, final String classifier, final boolean optional, final File file)
            throws InvalidVersionSpecificationException {
        super(groupId, artifactId, VersionRange.createFromVersionSpec(version), scope, type, classifier, null,
                optional);
        setArtifactHandler(new Handler(classifier));
        setFile(new File(file.getParentFile(),
                artifactId + "-" + VersionRange.createFromVersionSpec(version) + "-" + classifier + "." + type));
    }
}