blob: f5acf7a83db6951776d78a0a8227e15b9ffd9d5d [file] [log] [blame]
Marc Kupietz4f6ed422024-03-01 07:27:46 +01001plugins {
2 // Apply the org.jetbrains.kotlin.jvm Plugin to add support for Kotlin.
Marc Kupietzde917592025-10-31 15:44:27 +01003 id 'org.jetbrains.kotlin.jvm' version '2.2.21'
Marc Kupietz4f6ed422024-03-01 07:27:46 +01004
5 // Apply the application plugin to add support for building a CLI application in Java.
6 id 'application'
Marc Kupietz1b595992024-03-01 14:54:30 +01007 id 'com.github.johnrengelman.shadow' version '8.1.1'
Marc Kupietz4f6ed422024-03-01 07:27:46 +01008}
9
Marc Kupietz4f6ed422024-03-01 07:27:46 +010010repositories {
Marc Kupietz4f6ed422024-03-01 07:27:46 +010011 mavenCentral()
Marc Kupietz56a45562024-03-20 20:18:08 +010012 maven { url 'https://jitpack.io' }
Marc Kupietz4f6ed422024-03-01 07:27:46 +010013}
14
Marc Kupietz47b43c32024-03-27 20:43:32 +010015test {
Marc Kupietzfc18d282025-08-31 12:07:46 +020016 minHeapSize = "512m"
17 maxHeapSize = "4096m"
18 jvmArgs '-XX:MaxMetaspaceSize=1024m'
Marc Kupietz47b43c32024-03-27 20:43:32 +010019}
20
Marc Kupietz4f6ed422024-03-01 07:27:46 +010021dependencies {
22 // Align versions of all Kotlin components
23 implementation platform('org.jetbrains.kotlin:kotlin-bom')
24
25 // Use the Kotlin JDK 8 standard library.
26 implementation 'org.jetbrains.kotlin:kotlin-stdlib'
Marc Kupietzfc18d282025-08-31 12:07:46 +020027 implementation 'org.jetbrains.kotlinx:kotlinx-coroutines-core:1.10.2'
Marc Kupietz4f6ed422024-03-01 07:27:46 +010028
29 // This dependency is used by the application.
Marc Kupietzde917592025-10-31 15:44:27 +010030 implementation 'com.google.guava:guava:33.5.0-jre'
Marc Kupietz4f6ed422024-03-01 07:27:46 +010031
Marc Kupietz31122362024-03-02 11:13:37 +010032
Marc Kupietzfc18d282025-08-31 12:07:46 +020033 implementation ("info.picocli:picocli:4.7.7")
Marc Kupietz31122362024-03-02 11:13:37 +010034
Marc Kupietz4f6ed422024-03-01 07:27:46 +010035 // Use the Kotlin test library.
36 testImplementation 'org.jetbrains.kotlin:kotlin-test'
37
38 // Use the Kotlin JUnit integration.
39 testImplementation 'org.jetbrains.kotlin:kotlin-test-junit'
Marc Kupietzde917592025-10-31 15:44:27 +010040 testImplementation "org.jetbrains.kotlin:kotlin-test:2.2.21"
Marc Kupietz0c6e8772024-03-19 07:03:07 +010041
Marc Kupietz1465ce22024-03-26 09:51:17 +010042 implementation 'com.github.kupietz:cistern:v1.0.4'
Marc Kupietzaf682a42024-03-22 06:51:55 +010043 implementation 'org.maltparser:maltparser:1.9.2'
Marc Kupietzde917592025-10-31 15:44:27 +010044 implementation 'org.apache.opennlp:opennlp-tools:2.5.6'
Marc Kupietzfc18d282025-08-31 12:07:46 +020045 implementation 'org.slf4j:slf4j-simple:2.0.17'
Marc Kupietz916bdfe2024-09-20 09:02:57 +020046 implementation 'org.apache.ant:ant:1.10.15'
Marc Kupietzfc18d282025-08-31 12:07:46 +020047 implementation 'org.apache.commons:commons-compress:1.28.0'
Marc Kupietzd698f0e2025-11-01 20:00:07 +010048 implementation 'me.tongfei:progressbar:0.10.1'
Marc Kupietza92bacb2024-04-06 20:26:05 +020049
Marc Kupietz4f6ed422024-03-01 07:27:46 +010050}
51
Marc Kupietz8d875cc2025-10-31 15:36:33 +010052// Erzwinge JDK 21 Toolchain und Bytecode-Level 21
53java {
54 toolchain {
55 languageVersion = JavaLanguageVersion.of(21)
56 }
57}
Marc Kupietz4f6ed422024-03-01 07:27:46 +010058
Marc Kupietz8d875cc2025-10-31 15:36:33 +010059kotlin {
60 jvmToolchain(21)
61}
62
63// Für evtl. vorhandenen Java-Quellcode
64tasks.withType(JavaCompile).configureEach {
65 options.release = 21
66}
67
68tasks.withType(org.jetbrains.kotlin.gradle.tasks.KotlinCompile).configureEach {
69 kotlinOptions {
70 jvmTarget = "21"
71 // Falls verfügbar, sorgt dies für konsistente API-Targets ähnlich zu Java --release
72 // freeCompilerArgs += ["-Xjdk-release=21"]
73 }
74}
Marc Kupietz9da19db2024-04-01 11:06:51 +020075
Marc Kupietzf13fc7b2025-10-31 17:28:21 +010076// Version des Subprojekts explizit von Root erben
77version = rootProject.version
78
Marc Kupietz4f6ed422024-03-01 07:27:46 +010079application {
80 // Define the main class for the application.
Marc Kupietz07c60d32025-01-21 19:32:48 +010081 mainClass = 'de.ids_mannheim.korapxmltools.KorapXmlToolKt'
Marc Kupietz4f6ed422024-03-01 07:27:46 +010082}
83
84jar {
Marc Kupietzf13fc7b2025-10-31 17:28:21 +010085 // Standard-JAR als "plain" kennzeichnen, um Konflikte mit ShadowJar zu vermeiden
86 archiveClassifier.set('plain')
Marc Kupietz4f6ed422024-03-01 07:27:46 +010087 manifest.attributes(
88 'Class-Path': configurations.compileClasspath.collect { it.getName() }.join(' '),
Marc Kupietzde917592025-10-31 15:44:27 +010089 'Main-Class': "de.ids_mannheim.korapxmltools.KorapXmlToolKt",
90 'Implementation-Title': rootProject.name,
91 'Implementation-Version': project.version
Marc Kupietz4f6ed422024-03-01 07:27:46 +010092 )
Marc Kupietzf13fc7b2025-10-31 17:28:21 +010093}
94
95shadowJar {
96 archiveBaseName.set('korapxmltool')
97 archiveClassifier.set('')
98 archiveVersion.set(project.version.toString())
99 manifest.attributes(
100 'Main-Class': "de.ids_mannheim.korapxmltools.KorapXmlToolKt",
101 'Implementation-Title': rootProject.name,
102 'Implementation-Version': project.version
103 )
104}
105
106// Stelle sicher, dass assemble auch den ShadowJar erzeugt
107tasks.named('assemble') {
108 dependsOn tasks.named('shadowJar')
109}
110
111// Erzeuge zusätzlich eine nicht-versionierte Kopie korapxmltool.jar für stabile Skriptpfade
112tasks.register('shadowJarLatest', Copy) {
113 dependsOn tasks.named('shadowJar')
114 from({ tasks.shadowJar.get().archiveFile.get().asFile })
115 into({ tasks.shadowJar.get().destinationDirectory.get().asFile })
116 rename { String _ -> 'korapxmltool.jar' }
117}
118
119tasks.named('build') {
120 dependsOn tasks.named('shadowJarLatest')
Marc Kupietz4f6ed422024-03-01 07:27:46 +0100121}
122
123
124configurations {
125 runtimeLib.extendsFrom implementation
126}