scala maven插件没有将scala文件打包成jar

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了scala maven插件没有将scala文件打包成jar相关的知识,希望对你有一定的参考价值。

我是maven的新手,目前正尝试用它组装一个scala项目。项目结构:

dir
 |
 |--src/main/java
 |
 |--src/main/scala
 |
 |--pom.xml

我很惊讶从*.java编译的类最终在jar中,但是从*.scala编译的类没有。我将这些插件添加到pom.xml

<plugins>
    <plugin>
        <groupId>net.alchim31.maven</groupId>
        <artifactId>scala-maven-plugin</artifactId>
        <version>3.1.3</version>
    </plugin>
    <plugin>
        <artifactId>maven-compiler-plugin</artifactId>
        <configuration>
            <source>1.8</source>
            <target>1.8</target>
        </configuration>
    </plugin>
    <plugin>
        <groupId>org.apache.maven.plugins</groupId>
        <artifactId>maven-jar-plugin</artifactId>
        <version>2.4</version>
        <configuration>
            <archive>
                <manifest>
                    <addClasspath>true</addClasspath>
                    <classpathPrefix>lib/</classpathPrefix>
                    <mainClass>HelloWorld</mainClass>
                </manifest>
            </archive>
        </configuration>
    </plugin>
</plugins>

我虽然maven-jar-plugin负责组装jar文件。但由于某种原因,它不会添加scala编译的类。

问题:谁在执行.class后将jar文件添加到最终的mvn install?如何添加使用scala编译器编译的.class文件?

答案

mvn package将构建你的jar,但是maven-compiler-plugin只会编译你的java源文件而不是你的scala源文件。 Scala-maven-plugin可用于编译java和scala源代码。

我刚刚写了一篇博文,这可能有助于http://blog.rizvn.com/2016/04/scala-and-maven.html

你需要告诉maven关于src / main / scala,因为你将scala代码放在src / main / java下。这是通过构建部分完成的,如下所示:

<build>
    <sourceDirectory>src/main/scala</sourceDirectory>
    <testSourceDirectory>src/test/scala</testSourceDirectory>
 ...
</build>
另一答案

你可以尝试使用“scala-maven-plugin”代替这样的东西。然后执行maven目标:mvn clean package

<build>
<sourceDirectory>${basedir}/src</sourceDirectory>
<resources>
    <resource>
        <directory>${basedir}/src/test/resources</directory>
    </resource>
</resources>
<plugins>
    <plugin>
        <groupId>net.alchim31.maven</groupId>
        <artifactId>scala-maven-plugin</artifactId>
        <version>${scala-maven-plugin.version}</version>
        <configuration>
            <sourceDir>${basedir}/src</sourceDir>
            <outputDir>${basedir}/target/classes</outputDir>
        </configuration>
        <executions>
            <execution>
                <id>scala-compile-first</id>
                <phase>process-resources</phase>
                <goals>
                    <goal>compile</goal>
                </goals>
            </execution>
        </executions>
    </plugin>
 </plugins>

以上是关于scala maven插件没有将scala文件打包成jar的主要内容,如果未能解决你的问题,请参考以下文章

spark3的打包

eclipse安装scala插件及创建maven工程

IDEA下Scala Maven开发环境搭建

maven安装scala插件

一篇小短文让你了解Maven

带有 Scala 插件、Maven 和 Spark 的 Eclipse 项目