View Javadoc
1   /*
2    * Copyright (C) 2011 the original author or authors.
3    *
4    * Licensed under the Apache License, Version 2.0 (the "License");
5    * you may not use this file except in compliance with the License.
6    * You may obtain a copy of the License at
7    *
8    *     http://www.apache.org/licenses/LICENSE-2.0
9    *
10   * Unless required by applicable law or agreed to in writing, software
11   * distributed under the License is distributed on an "AS IS" BASIS,
12   * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13   * See the License for the specific language governing permissions and
14   * limitations under the License.
15   */
16  
17  package org.codehaus.gmavenplus.mojo;
18  
19  import org.apache.maven.artifact.DependencyResolutionRequiredException;
20  import org.apache.maven.plugin.MojoExecutionException;
21  import org.apache.maven.plugins.annotations.LifecyclePhase;
22  import org.apache.maven.plugins.annotations.Mojo;
23  import org.apache.maven.plugins.annotations.Parameter;
24  import org.apache.maven.plugins.annotations.ResolutionScope;
25  import org.apache.maven.shared.model.fileset.FileSet;
26  
27  import java.io.File;
28  import java.lang.reflect.InvocationTargetException;
29  import java.net.MalformedURLException;
30  
31  
32  /**
33   * Compiles the main sources.
34   * Note that this mojo requires Groovy >= 1.5.0, and >= 2.0.0-beta-3 (the indy version) for compiling with invokedynamic option.
35   *
36   * @author Keegan Witt
37   * @since 1.0-beta-1
38   */
39  @Mojo(name = "compile", defaultPhase = LifecyclePhase.COMPILE, requiresDependencyResolution = ResolutionScope.COMPILE, threadSafe = true)
40  public class CompileMojo extends AbstractCompileMojo {
41  
42      /**
43       * The Groovy source files (relative paths).
44       * Default: "${project.basedir}/src/main/groovy/**/*.groovy"
45       */
46      @Parameter
47      protected FileSet[] sources;
48  
49      /**
50       * The location for the compiled classes.
51       */
52      @Parameter(defaultValue = "${project.build.outputDirectory}")
53      protected File outputDirectory;
54  
55      /**
56       * Executes this mojo.
57       *
58       * @throws MojoExecutionException If an unexpected problem occurs (causes a "BUILD ERROR" message to be displayed)
59       */
60      @Override
61      public void execute() throws MojoExecutionException {
62          try {
63              try {
64                  getLog().debug("Project compile classpath:\n" + project.getCompileClasspathElements());
65              } catch (DependencyResolutionRequiredException e) {
66                  getLog().debug("Unable to log project compile classpath");
67              }
68              doCompile(getFiles(sources, false), project.getCompileClasspathElements(), outputDirectory);
69          } catch (ClassNotFoundException e) {
70              throw new MojoExecutionException("Unable to get a Groovy class from classpath (" + e.getMessage() + "). Do you have Groovy as a compile dependency in your project?", e);
71          } catch (InvocationTargetException e) {
72              throw new MojoExecutionException("Error occurred while calling a method on a Groovy class from classpath.", e);
73          } catch (InstantiationException e) {
74              throw new MojoExecutionException("Error occurred while instantiating a Groovy class from classpath.", e);
75          } catch (IllegalAccessException e) {
76              throw new MojoExecutionException("Unable to access a method on a Groovy class from classpath.", e);
77          } catch (DependencyResolutionRequiredException e) {
78              throw new MojoExecutionException("Compile dependencies weren't resolved.", e);
79          } catch (MalformedURLException e) {
80              throw new MojoExecutionException("Unable to add project compile dependencies to classpath.", e);
81          }
82      }
83  
84  }