我已经编写了一个简单的kotlin源文件以便开始使用,并且还有一个gradle脚本文件。 但我不知道如何将主func添加到清单,以便该jar可以自我执行。用Gradle和Kotlin构建一个可自行执行的jar
这里我的build.gradle脚本:
buildscript {
repositories {
mavenCentral()
}
dependencies {
classpath 'org.jetbrains.kotlin:kotlin-gradle-plugin:0.9.66'
}
}
apply plugin: "kotlin"
repositories {
mavenCentral()
}
dependencies {
compile 'org.jetbrains.kotlin:kotlin-stdlib:0.9.66'
}
jar {
manifest {
attributes 'Main-Class': 'com.loloof64.kotlin.exps.ExpsPackage'
}
}
这里是我的com.loloof64.kotlin.exps.Multideclarations.kt
package com.loloof64.kotlin.exps
class Person(val firstName: String, val lastName: String) {
fun component1(): String {
return firstName
}
fun component2(): String {
return lastName
}
}
fun main(args: Array <String>) {
val(first, last) = Person("Laurent", "Bernabé")
println("First name : $first - Last name : $last")
}
当我启动从终端的jar(Java的罐子MYJar.jar)我得到了下面的堆栈跟踪,告诉我kotlin反射库类缺失,并且确实没有添加到jar中。似乎我错过了最后一个罐子里的kotlin编译器工件类,还有kotlin-stdlib源,但我不知道如何调整gradle构建。
$> java -jar build/libs/kotlin_exps.jar
Exception in thread "main" java.lang.NoClassDefFoundError: kotlin/reflect/jvm/internal/InternalPackage
at com.loloof64.kotlin.exps.ExpsPackage.<clinit>(MultiDeclarations.kt)
Caused by: java.lang.ClassNotFoundException: kotlin.reflect.jvm.internal.InternalPackage
at java.net.URLClassLoader$1.run(URLClassLoader.java:372)
at java.net.URLClassLoader$1.run(URLClassLoader.java:361)
at java.security.AccessController.doPrivileged(Native Method)
at java.net.URLClassLoader.findClass(URLClassLoader.java:360)
at java.lang.ClassLoader.loadClass(ClassLoader.java:424)
at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:308)
at java.lang.ClassLoader.loadClass(ClassLoader.java:357)
... 1 more
我使用科特林0.9.66和gradle这个2.1
请注意,Kotlin为诸如'main'等顶级函数生成的类名是在同一个文件中定义的包,以及附加了'KT'的文件名。在你的情况下,这将是'com.loloof64.kotlin.exps.MultideclarationsKT'。您可以通过在文件顶部添加'@file:JvmName(“OtherName”)'来为文件中的所有顶级函数定义一个新的类名,从而改变这种行为。 – 2015-12-31 00:57:42