View Javadoc

1   /*
2    * #%L
3    * Native ARchive plugin for Maven
4    * %%
5    * Copyright (C) 2002 - 2014 NAR Maven Plugin developers.
6    * %%
7    * Licensed under the Apache License, Version 2.0 (the "License");
8    * you may not use this file except in compliance with the License.
9    * You may obtain a copy of the License at
10   * 
11   * http://www.apache.org/licenses/LICENSE-2.0
12   * 
13   * Unless required by applicable law or agreed to in writing, software
14   * distributed under the License is distributed on an "AS IS" BASIS,
15   * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
16   * See the License for the specific language governing permissions and
17   * limitations under the License.
18   * #L%
19   */
20  package com.github.maven_nar;
21  
22  import java.io.File;
23  
24  import org.apache.maven.artifact.Artifact;
25  import org.apache.maven.artifact.DefaultArtifact;
26  import org.apache.maven.artifact.handler.ArtifactHandler;
27  import org.apache.maven.artifact.versioning.InvalidVersionSpecificationException;
28  import org.apache.maven.artifact.versioning.VersionRange;
29  
30  /**
31   * NarArtifact with its own type, classifier and artifactHandler.
32   *
33   * @author Mark Donszelmann
34   */
35  public class AttachedNarArtifact extends DefaultArtifact {
36    private class Handler implements ArtifactHandler {
37      private final String classifier;
38  
39      Handler(final String classifier) {
40        this.classifier = classifier;
41      }
42  
43      @Override
44      public String getClassifier() {
45        return this.classifier;
46      }
47  
48      @Override
49      public String getDirectory() {
50        return "nars";
51      }
52  
53      @Override
54      public String getExtension() {
55        return "nar";
56      }
57  
58      @Override
59      public String getLanguage() {
60        return "native";
61      }
62  
63      @Override
64      public String getPackaging() {
65        return "nar";
66      }
67  
68      @Override
69      public boolean isAddedToClasspath() {
70        return true;
71      }
72  
73      @Override
74      public boolean isIncludesDependencies() {
75        return false;
76      }
77    }
78  
79    // NOTE: not used
80    public AttachedNarArtifact(final Artifact parent, final String type, final String classifier) {
81      super(parent.getGroupId(), parent.getArtifactId(), parent.getVersionRange(), parent.getScope(), type, classifier,
82          null, parent.isOptional());
83      setArtifactHandler(new Handler(classifier));
84    }
85  
86    public AttachedNarArtifact(final String groupId, final String artifactId, final String version, final String scope,
87        final String type, final String classifier, final boolean optional, final File file)
88        throws InvalidVersionSpecificationException {
89      super(groupId, artifactId, VersionRange.createFromVersionSpec(version), scope, type, classifier, null, optional);
90      setArtifactHandler(new Handler(classifier));
91      setFile(new File(file.getParentFile(), artifactId + "-" + VersionRange.createFromVersionSpec(version) + "-"
92          + classifier + "." + type));
93    }
94  }