使用JNI依赖项,应用程序和eclipse插件构建Gradle

时间:2013-02-01 21:20:21

标签: eclipse java-native-interface native gradle lwjgl

我正在尝试使用Gradle的示例LWJGL应用程序。 LWJGL具有OpenGL和OpenAL的本机绑定,在jar lwjgl-platform-2.8.5-natives-windows.jar等等,然而,Gradle似乎并没有意识到这一点。

应用程序插件的distZip任务正确地将所有jar文件复制到zip中的lib目录中,但是,在.bat文件中,它只将上述本机jar放在类路径上,它不会将它作为显式本机传递给java

同样,Eclipse项目生成也无法设置给定依赖项的“本机库位置”。

是否有任何官方解决方案可以将本机库正确添加到生成的应用程序或Eclipse项目中,如果没有,是否有任何关于此限制的黑客攻击?

我的gradle.build:

apply plugin: 'java'
apply plugin: 'application'
apply plugin: 'eclipse'

sourceCompatibility = 1.7

mainClassName = 'org.lwjgl.examples.Game'

repositories {
    mavenCentral();
}

dependencies {
    compile group: 'com.google.guava', name: 'guava', version: 'latest.release'
    compile group: 'org.apache.commons', name: 'commons-lang3', version: 'latest.release'
    compile group: 'org.lwjgl.lwjgl', name: 'lwjgl', version: 'latest.release'

    testCompile group: 'com.jayway.awaitility', name: 'awaitility', version: 'latest.release'
    testCompile group: 'junit', name: 'junit', version: 'latest.release'
    testCompile group: 'org.hamcrest', name: 'hamcrest-all', version: 'latest.release'
    testCompile group: 'org.mockito', name: 'mockito-core', version: 'latest.release'
}

jar {
    baseName = rootProject.name
    version = System.env['BUILD_NUMBER']
    version = version == null ? 0 : version
    manifest {
        attributes("Implementation-Title": baseName, "Implementation-Version": version)
    }
}

生成的zip分发内容:

/lib//bin/tyle
/lib//bin/tyle.bat
/lib/commons-lang3-3.1.jar
/lib/guava-14.0-rc2.jar
/lib/jinput-2.0.5.jar
/lib/jinput-platform-2.0.5-natives-linux.jar
/lib/jinput-platform-2.0.5-natives-osx.jar
/lib/jinput-platform-2.0.5-natives-windows.jar
/lib/jutils-1.0.0.jar
/lib/lwjgl-2.8.5.jar
/lib/lwjgl-platform-2.8.5-natives-linux.jar
/lib/lwjgl-platform-2.8.5-natives-osx.jar
/lib/lwjgl-platform-2.8.5-natives-windows.jar
/lib/tyle-0.jar

lwjgl-platform-2.8.5-natives-windows.jar的内容:

META-INF/MANIFEST.MF
lwjgl.dll
lwjgl64.dll
OpenAL32.dll
OpenAL64.dll

1 个答案:

答案 0 :(得分:4)

我一直在努力解决类似的问题,并开始使用Gradle Natives Plugin来管理Java库的本机依赖项。另请参阅博客文章“Going Native with Gradle”,我将详细介绍。

基本上它将提供的本机库解压缩到“natives”构建目录中以供使用和进一步打包。