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 org.apache.maven.plugin.MojoExecutionException;
23  import org.apache.maven.plugin.MojoFailureException;
24  import org.apache.maven.plugins.annotations.LifecyclePhase;
25  import org.apache.maven.plugins.annotations.Mojo;
26  
27  /**
28   * Create the nar.properties file.
29   * 
30   * @author GDomjan
31   */
32  @Mojo(name = "nar-prepare-package", defaultPhase = LifecyclePhase.PREPARE_PACKAGE, requiresProject = true)
33  public class NarPreparePackageMojo extends AbstractNarMojo {
34  
35    // TODO: this is working of what is present rather than what was requested to
36    // be built, POM ~/= artifacts!
37    @Override
38    public final void narExecute() throws MojoExecutionException, MojoFailureException {
39      // let the layout decide which (additional) nars to attach
40      getLayout().prepareNarInfo(getTargetDirectory(), getMavenProject(), getNarInfo(), this);
41  
42      getNarInfo().writeToDirectory(this.classesDirectory);
43    }
44  
45  }