当前位置: 首页 > 知识库问答 >
问题:

如何在使用Gradle构建脂肪罐时编译不同的口味

蓝宜
2023-03-14

我想在Java项目中包含V8(“J2V8”)的Java绑定。原因是:(i)V8 JavaScript引擎比JRE附带的JavaScript引擎快得多;(ii)我使用的库仅在JavaScript中可用,并且要花费大量的精力到Java端口。

    null

我目前正在创建脂肪罐子使用阴影插件。

注意,该项目不是Android项目。在那里,有了Android插件,这似乎是直截了当的。

第一个想法是引入配置和特定于配置的依赖关系:

configurations {
    linux_x86_64Compile.extendsFrom compile
    macosx_x86_64Compile.extendsFrom compile
    windows_x86_32Compile.extendsFrom compile
    windows_x86_64Compile.extendsFrom compile
}

dependencies {
    compile configuration: 'linux_x86_64',   group: 'com.eclipsesource.j2v8', name: 'j2v8_linux_x86_x64',  version: '4.6.0'
    compile configuration: 'macosx_x86_64',  group: 'com.eclipsesource.j2v8', name: 'j2v8_macosx_x86_x64', version: '4.6.0'
    compile configuration: 'windows_x86_32', group: 'com.eclipsesource.j2v8', name: 'j2v8_win32_x86',      version: '4.6.0'
    compile configuration: 'windows_x86_64', group: 'com.eclipsesource.j2v8', name: 'j2v8_win32_x86_x64',  version: '4.6.0'
...
}
task releaseSingleJar(dependsOn: "shadowJar", name) {
    doLast {
        copy {
            from("$buildDir/libs/JabRef-${project.version}-fat.jar")
            into("$buildDir/releases/")

            rename { String fileName ->
                fileName.replace('-fat', '-$name')
            }
        }
    }
}

task releaseJars() {
  forEach name in "linux_x86_64", "macosx_x86_64", "windows_x86_32", "windows_x86_64", "all":
     if (name != "all") activate configuration $name
     releaseSingleJar($name)
    null
  • 如何为不同的产品口味定义不同的依赖关系
  • gradle:为库的特定风格添加依赖项
  • 通过Gradle中的任务更改依赖项
  • 使用gradle为不同的应用口味使用不同的资源

共有1个答案

楚举
2023-03-14

您可能会对我的gradle-java-flavours插件感兴趣,该插件在java专案中为每个flavours创建源代码集、配置以及编译、jar和测试任务。

例如:

import com.github.jengelman.gradle.plugins.shadow.tasks.*
plugins {
    id 'com.lazan.javaflavours' version '1.2'
    id 'com.github.johnrengelman.shadow' version '1.2.4'
}
def flavours = ['linux_x86_64', 'macosx_x86_64', ...]
javaFlavours {
    flavours.each {
        flavour it
    }
}
dependencies {
    linux_x86_64Compile      'aaa:aaa:1.0'
    linux_x86_64Runtime      'bbb:bbb:1.0'
    macosx_x86_64TestCompile 'ccc:ccc:3.0'
}
flavours.each { String flavour ->
    SourceSet flavourSourceSet = sourceSets.getByName(flavour)
    Configuration flavourRuntime = configurations.getByName("${flavour}Runtime")
    JavaCompile flavourCompileTask = tasks.getByName("compile${flavour.capitalize()}Java")
    Task shadowJarTask = tasks.create(name: "${flavour}ShadowJar", type: ShadowJar) {
        classifier = "${flavour}-all"
        dependsOn flavourCompileTask 
        // todo configure (likely based on Configuration and SourceSet)
    }
    artifacts {
        archives shadowJarTask 
    }
    // wire the task into the DAG
    assemble.dependsOn shadowJarTask
}
 类似资料:
  • 我知道不是一个有效的阶段,但我只是想说明我试图完成什么,即只有在提供选项时才构建fat jar的条件安装。

  • 我正在用Spring Boot,Jpa和MySQL连接器编写java控制台应用程序。我怎样才能轻松地排除所有不必要的脂肪从我的脂肪罐?

  • 我使用JarSplice创建了一个胖jar文件,但是当我启动它时,我得到一个窗口(大小可以),它在半秒后关闭。。。 在“addjars”部分中,我添加了从Eclipse导出的jar文件,以及我正在使用的所有库jar。在本机部分,我只为lwjgl添加Windows本机。我想我写了正确的主类。 我做错了什么?我怎样才能解决这个问题? 注意:我使用的是最新版本的eclipse和jdk。

  • 我对Gradle和shadow jar(Maven的Shade插件的Gradle版本)是新手。我正在构建一个胖jar,我想在其中合并服务文件(这就是我首先使用shadowjar的原因)。根据文档,shadowJar任务继承自gradle Jar任务。因此,我们可以假设它将完全像jar任务一样工作。 下面是jar任务的片段: 结果,它产生了一个脂肪罐与所有的依赖关系爆炸,什么是预期的。当我将任务名称

  • 我将Gradle用于一个简单的Java项目,并希望生成一个fat JAR,其中还包含源代码。 我准备了一个示例存储库:https://github.com/szarnyasg/gradle-shadowjar-source.我尝试了这个配置: 我可以通过以下方式构建此功能: 这将在目录中生成两个JAR文件: -没有源的胖JAR -一个(仅)包含源的JAR Gradle Shadow插件的文档说明

  • 我有一个使用spark的scala多项目,并尝试使用sbt插件sbt-assembly 0.14.3来制作一个胖罐子。我的建筑。SBT看起来像这样: 我想创建一个子项目的fat jar,以便这个fat jar包含项目核心的所有库和代码。我尝试了以下方法: