使用Maven

插件和版本

Kotlin-maven-plugin 可以编译 Kotlin 资源和模块。现在只有 Maven V3 支持

通过 Kotlin.version 定义你想要的 Kotlin 版本。可以有以下的值

X.Y.SNAPSHOT:对应版本 X.Y 的快照,在 CI 服务器上的每次成功构建的版本。这些版本不是真正的稳定版,只是推荐用来测试新编辑器的功能的。现在所有的构建都是作为 0.1-SNAPSHOT 发表的。你可以参看configure a snapshot repository in the pom file

X.Y.X: 对应版本 X.Y.Z 的 release 或 milestone ,自动升级。它们是文件构建。Release 版本发布在 Maven Central 仓库。在 pom 文件里不需要多余的配置。

milestone 和 版本的对应关系如下:

Milestone Version
M12.1 0.12.613
M12 0.12.200
M11.1 0.11.91.1
M11 0.11.91
M10.1 0.10.195
M10 0.10.4
M9 0.9.66
M8 0.8.11
M7 0.7.270
M6.2 0.6.1673
M6.1 0.6.602
M6 0.6.69
M5.3 0.5.998

配置快照仓库

使用 kotlin 版本的快照,需要在 pom 中这样定义:

  1. <repositories>
  2. <repository>
  3. <id>sonatype.oss.snapshots</id>
  4. <name>Sonatype OSS Snapshot Repository</name>
  5. <url>http://oss.sonatype.org/content/repositories/snapshots</url>
  6. <releases>
  7. <enabled>false</enabled>
  8. </releases>
  9. <snapshots>
  10. <enabled>true</enabled>
  11. </snapshots>
  12. </repository>
  13. </repositories>
  14. <pluginRepositories>
  15. <pluginRepository>
  16. <id>sonatype.oss.snapshots</id>
  17. <name>Sonatype OSS Snapshot Repository</name>
  18. <url>http://oss.sonatype.org/content/repositories/snapshots</url>
  19. <releases>
  20. <enabled>false</enabled>
  21. </releases>
  22. <snapshots>
  23. <enabled>true</enabled>
  24. </snapshots>
  25. </pluginRepository>
  26. </pluginRepositories>

依赖

kotlin 有一些扩展标准库可以使用。在 pom 文件中使用如下的依赖:

  1. <dependencies>
  2. <dependency>
  3. <groupId>org.jetbrains.kotlin</groupId>
  4. <artifactId>kotlin-stdlib</artifactId>
  5. <version>${kotlin.version}</version>
  6. </dependency>
  7. </dependencies>

只编译 kotlin 源码

编译源码需要在源码文件夹打一个标签:

  1. <sourceDirectory>${project.basedir}/src/main/kotlin</sourceDirectory>
  2. <testSourceDirectory>${project.basedir}/src/test/kotlin</testSourceDirectory>

在编译资源是需要引用kotlin Maven Plugin:

  1. <plugin>
  2. <artifactId>kotlin-maven-plugin</artifactId>
  3. <groupId>org.jetbrains.kotlin</groupId>
  4. <version>${kotlin.version}</version>
  5. <executions>
  6. <execution>
  7. <id>compile</id>
  8. <phase>compile</phase>
  9. <goals> <goal>compile</goal> </goals>
  10. </execution>
  11. <execution>
  12. <id>test-compile</id>
  13. <phase>test-compile</phase>
  14. <goals> <goal>test-compile</goal> </goals>
  15. </execution>
  16. </executions>
  17. </plugin>

编译 kotlin 和 java 资源

为了编译混合代码的应用,Kotlin 编译器应该在 java 编译器之前先工作。在 maven 中意味着 kotlin-maven-plug 应该在 maven-compiler-plugin 之前。

  1. <plugin>
  2. <artifactId>kotlin-maven-plugin</artifactId>
  3. <groupId>org.jetbrains.kotlin</groupId>
  4. <version>0.1-SNAPSHOT</version>
  5. <executions>
  6. <execution>
  7. <id>compile</id>
  8. <phase>process-sources</phase>
  9. <goals> <goal>compile</goal> </goals>
  10. </execution>
  11. <execution>
  12. <id>test-compile</id>
  13. <phase>process-test-sources</phase>
  14. <goals> <goal>test-compile</goal> </goals>
  15. </execution>
  16. </executions>
  17. </plugin>

使用扩展的注解

kotlin 使用扩展的注解解析 java 库的信息。为了明确这些注解,你需要像下面这样:

  1. <plugin>
  2. <artifactId>kotlin-maven-plugin</artifactId>
  3. <groupId>org.jetbrains.kotlin</groupId>
  4. <version>0.1-SNAPSHOT</version>
  5. <configuration>
  6. <annotationPaths>
  7. <annotationPath>path to annotations root</annotationPath>
  8. </annotationPaths>
  9. </configuration>

例子

你可以在 Github 仓库参考