gradle - как мне создать банку с директорией lib с другими банками в ней? - PullRequest
62 голосов
/ 10 августа 2010

В gradle - как я могу вставить jar в мой jar-файл сборки в lib каталог (в частности, lib / enttoolkit.jar и lib / mail.jar)?

Ответы [ 9 ]

35 голосов
/ 10 августа 2010

Отменено дословно от: http://docs.codehaus.org/display/GRADLE/Cookbook#Cookbook-Creatingafatjar

Gradle 0,9:

jar {
    from configurations.compile.collect { it.isDirectory() ? it : zipTree(it) }
}

Gradle 0,8:

jar.doFirst {
    for(file in configurations.compile) {
        jar.merge(file)
    }
}

Приведенные выше фрагменты будут включать только зависимости компиляции для этого проекта, а не какие-либо переходные зависимости времени выполнения. Если вы также хотите объединить их, замените файл configurations.compile файлом configurations.runtime.

РЕДАКТИРОВАТЬ : выбирайте только те банки, которые вам нужны

Создайте новую конфигурацию, возможно, ReleaseJars

configurations {
    releaseJars
}

Добавьте нужные банки в эту конфигурацию

dependencies {
    releaseJars group: 'javax.mail', name: 'mail', version: '1.4'
    //etc
}

затем используйте эту конфигурацию в задаче jar, описанной выше.

31 голосов
/ 20 февраля 2012

Если у вас есть все фляги внутри директории (давайте назовем это libs) в вашем проекте, вам нужно только это:

jar {
    into('lib') {
        from 'libs'
    }
}

Полагаю, более вероятно, что эти jar-файлы являются зависимостями какого-либо рода. Тогда вы можете сделать это так:

configurations {
    // configuration that holds jars to copy into lib
    extraLibs
}
dependencies {
    extraLibs 'org.something:something-dep1:version'
    extraLibs 'org.something:something-dep2:version'
}

jar {
    into('lib') {
        from configurations.extraLibs
    }
}
20 голосов
/ 19 марта 2012

просто:

task copyToLib( type: Copy ) {
    into "$buildDir/libs/lib"
    from configurations.runtime
}

jar { dependsOn copyToLib }

запустить его:

$ gradle jar
...
$ tree build/libs

build/libs
├── your-project-0.0.1.BUILD-SNAPSHOT.jar
└── lib
    ├── akka-actor-2.0.jar
    ├── akka-camel-2.0.jar
    ├── ... ... ...
    ├── spring-expression-3.1.0.RELEASE.jar
    └── zmq-2.1.9.jar

1 directory, 46 files
7 голосов
/ 18 декабря 2014

Ниже можно попробовать код. Это зависит от задачи jar и имеет тип Jar

task createJobJar(dependsOn:jar,type:Jar) {
    manifest {
        attributes(
                "Implementation-Title": 'Job '
                ,"Implementation-Version": version
        )
    }
    classifier 'job'
    destinationDir new File("$buildDir")
    into('libs'){
         from configurations.compile
    }
    into('classes'){
        from "$buildDir/classes"
    }
    into('resources'){
        from "$projectDir/src/main/resources"
    }
    into('scripts'){
        from "$projectDir/src/main/scripts"
    }
}

Приведенный выше код упаковывает разное содержимое в разные каталоги. Проверено на Gradle 2.2

7 голосов
/ 12 марта 2012

Мне также нужно было сделать что-то похожее, и я не смог понять, что Гус и Стигкдж предложили работать, но с их помощью подобрались достаточно близко, чтобы заставить его работать (пример Гуса взорвался для закрытия dependencies { compile { extendsFrom myLibs }} для меня.

apply plugin: 'groovy'

repositories {
    mavenCentral()
}

configurations {
    // custom config of files we want to include in our fat jar that we send to hadoop
    includeInJar
}

dependencies {
    includeInJar 'org.codehaus.groovy:groovy:1.8.6'

    configurations.compile.extendsFrom(configurations.includeInJar)
}

jar {
    into('lib') {
        println "includeInJar: " + configurations.includeInJar.collect { File file -> file }
        from configurations.includeInJar
    }

}

Затем выполнение gradle jar и проверка созданного фляги дает мне этот вывод, показывая, что я получаю файл фляги, чтобы иметь groovy, а также все фляги, от которых это зависит внутри "толстого фляги":

%  gradle jar                                                                                                                         
includeInJar: [/Users/tnaleid/.gradle/caches/artifacts-8/filestore/org.codehaus.groovy/groovy/1.8.6/jar/553ca93e0407c94c89b058c482a404427ac7fc72/groovy-1.8.6.jar, /Users/tnaleid/.gradle/caches/artifacts-8/filestore/antlr/antlr/2.7.7/jar/83cd2cd674a217ade95a4bb83a8a14f351f48bd0/antlr-2.7.7.jar, /Users/tnaleid/.gradle/caches/artifacts-8/filestore/asm/asm/3.2/jar/9bc1511dec6adf302991ced13303e4140fdf9ab7/asm-3.2.jar, /Users/tnaleid/.gradle/caches/artifacts-8/filestore/asm/asm-tree/3.2/jar/cd792e29c79d170c5d0bdd05adf5807cf6875c90/asm-tree-3.2.jar, /Users/tnaleid/.gradle/caches/artifacts-8/filestore/asm/asm-commons/3.2/jar/e7a19b8c60589499e35f5d2068d09013030b8891/asm-commons-3.2.jar, /Users/tnaleid/.gradle/caches/artifacts-8/filestore/asm/asm-util/3.2/jar/37ebfdad34d5f1f45109981465f311bbfbe82dcf/asm-util-3.2.jar, /Users/tnaleid/.gradle/caches/artifacts-8/filestore/asm/asm-analysis/3.2/jar/c624956db93975b7197699dcd7de6145ca7cf2c8/asm-analysis-3.2.jar]
:compileJava UP-TO-DATE
:compileGroovy UP-TO-DATE
:processResources UP-TO-DATE
:classes UP-TO-DATE
:jar

BUILD SUCCESSFUL

Total time: 3.387 secs

%  jar tvf build/libs/gradletest.jar                                                                                                  
     0 Mon Mar 12 11:40:00 CDT 2012 META-INF/
    25 Mon Mar 12 11:40:00 CDT 2012 META-INF/MANIFEST.MF
     0 Mon Mar 12 11:40:00 CDT 2012 lib/
5546084 Mon Mar 05 13:13:32 CST 2012 lib/groovy-1.8.6.jar
445288 Mon Mar 05 13:13:38 CST 2012 lib/antlr-2.7.7.jar
 43398 Mon Mar 05 13:13:40 CST 2012 lib/asm-3.2.jar
 21878 Mon Mar 05 13:13:40 CST 2012 lib/asm-tree-3.2.jar
 33094 Mon Mar 05 13:13:40 CST 2012 lib/asm-commons-3.2.jar
 36551 Mon Mar 05 13:13:40 CST 2012 lib/asm-util-3.2.jar
 17985 Mon Mar 05 13:13:40 CST 2012 lib/asm-analysis-3.2.jar
6 голосов
/ 24 мая 2011

Мне нужно было то же, что вы просили, и использовал этот метод.вам может не потребоваться объявление пользовательской конфигурации, но мне нужно было отделить локально используемые файлы JAR от тех, которые объявлены в файле супер-сборки.

1 голос
/ 05 марта 2019

У меня была такая же проблема.Я решил это так:

Скопируйте файлы в папку lib с помощью copyToLib и укажите ссылку на Class-Path

ext.mainClass = 'test.main'

dependencies {
    compile fileTree(include: ['*.jar'], dir: 'libs')
    compile 'com.google.code.gson:gson:2.8.2'
    //....
}

jar {
    from "$buildDir/libs/lib"
    manifest {
        attributes 'Main-Class': 'test.main',
        'Class-Path': configurations.compile.collect { 'lib/'+it.getName() }.join(' ')
    }
}

task copyToLib(type: Copy) {
    into "$buildDir/libs/lib"
    from configurations.compile
}

build.dependsOn(copyToLib)
0 голосов
/ 27 июня 2017
task <taskname>(type: Jar) {
    archiveName 'nameofjar.jar'
    doFirst {
    manifest {
            attributes 'Class-Path': configurations.compile.files.collect{ project.uri(it) }.join(' ')
        }
    }
}
0 голосов
/ 12 апреля 2017

В моем случае мне нужно было включить содержимое корневого проекта Jar в подпроект Jar.Итак, чтобы он работал, можно использовать этот шаблон:

jar{
  manifest{
    attributes 'Main-Class':'<main class>'
  }
  def conf= configurations.find {it.name.equals('compile') }
  File jar= conf.files.find {it.name.contains('<name or part of the name of produced Jar>')}

  FileTree fileTree=zipTree(jar)
  from fileTree
}

Мой пример:

jar{
   manifest{
       attributes 'Main-Class':'alexiy.jace.Jace'
   }
   description='Make a runnable API Jar'
   def conf= configurations.find {it.name.equals('compile') }
   File tools= conf.files.find {it.name.contains('Tools')}

   FileTree fileTree=zipTree(tools)
   from fileTree
}
...