View Javadoc
1   /*
2    * Licensed to the Apache Software Foundation (ASF) under one
3    * or more contributor license agreements.  See the NOTICE file
4    * distributed with this work for additional information
5    * regarding copyright ownership.  The ASF licenses this file
6    * to you under the Apache License, Version 2.0 (the
7    * "License"); you may not use this file except in compliance
8    * with the License.  You may obtain a copy of the License at
9    *
10   *   http://www.apache.org/licenses/LICENSE-2.0
11   *
12   * Unless required by applicable law or agreed to in writing,
13   * software distributed under the License is distributed on an
14   * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
15   * KIND, either express or implied.  See the License for the
16   * specific language governing permissions and limitations
17   * under the License.
18   */
19  package org.apache.maven.plugins.source;
20  
21  import java.util.Collections;
22  import java.util.List;
23  
24  import org.apache.maven.model.Resource;
25  import org.apache.maven.plugins.annotations.LifecyclePhase;
26  import org.apache.maven.plugins.annotations.Mojo;
27  import org.apache.maven.plugins.annotations.Parameter;
28  import org.apache.maven.project.MavenProject;
29  
30  /**
31   * This goal bundles all the sources into a jar archive. This goal functions the same as the jar goal but does not fork
32   * the build and is suitable for attaching to the build lifecycle.
33   *
34   * @author pgier
35   * @since 2.1
36   */
37  @Mojo(name = "jar-no-fork", defaultPhase = LifecyclePhase.PACKAGE, threadSafe = true)
38  public class SourceJarNoForkMojo extends AbstractSourceJarMojo {
39      /**
40       * @since 2.2
41       */
42      @Parameter(property = "maven.source.classifier", defaultValue = "sources")
43      protected String classifier;
44  
45      /**
46       * {@inheritDoc}
47       */
48      protected List<String> getSources(MavenProject p) {
49          return p.getCompileSourceRoots();
50      }
51  
52      /**
53       * {@inheritDoc}
54       */
55      protected List<Resource> getResources(MavenProject p) {
56          if (excludeResources) {
57              return Collections.emptyList();
58          }
59  
60          return p.getResources();
61      }
62  
63      /**
64       * {@inheritDoc}
65       */
66      protected String getClassifier() {
67          return classifier;
68      }
69  }