Introduction Setting upThis page describes how you can add Lamp to your own projects, using Gradle or Maven.
Adding Lamp dependency
To add Lamp to your project, add the following (depending on your project structure):
pom.xml build.gradle build.gradle.kts
Copy <dependencies>
<!-- Required for all platforms -->
<dependency>
<groupId>io.github.revxrsal</groupId>
<artifactId>lamp.common</artifactId>
<version>[VERSION]</version>
</dependency>
<!-- Add your specific platform module here -->
<dependency>
<groupId>io.github.revxrsal</groupId>
<artifactId>lamp.[PLATFORM]</artifactId>
<version>[VERSION]</version>
</dependency>
</dependencies>
Copy dependencies {
implementation 'io.github.revxrsal:lamp.common:[VERSION]'
implementation 'io.github.revxrsal:lamp.[PLATFORM]:[VERSION]'
}
Copy dependencies {
implementation("io.github.revxrsal:lamp.common:[VERSION]")
implementation("io.github.revxrsal:lamp.[PLATFORM]:[VERSION]")
}
Latest version:
Where [PLATFORM]
is any of the following:
bukkit
: Contains integrations for the Bukkit platform
bungee
: Contains integrations for the BungeeCord API
sponge
: Contains integrations for the Sponge platform (version 8+)
paper
: Contains extra features for the PaperMC API
minestom
: Contains integrations for the Minestom platform
fabric
: Contains integrations for the Fabric modding API
cli
: A minimal implementation of the Lamp APIs for command-line applications
Optional: Preserve parameter names
Lamp identifies parameters by their names and uses them to generate relevant command metadata. By default, Java does not preserve parameter names reflectively. You need to add the following to your project:
pom.xml build.gradle build.gradle.kts
Copy <plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<version>3.8.0</version>
<configuration>
<compilerArgs>
<!-- Preserves parameter names -->
<arg>-parameters</arg>
</compilerArgs>
</configuration>
</plugin>
</plugins>
Copy compileJava {
// Preserve parameter names in the bytecode
options.compilerArgs += ["-parameters"]
}
// optional: if you're using Kotlin
compileKotlin {
kotlinOptions.javaParameters = true
}
Copy tasks.withType<JavaCompile> {
// Preserve parameter names in the bytecode
options.compilerArgs.add("-parameters")
}
// optional: if you're using Kotlin
tasks.withType<KotlinJvmCompile> {
compilerOptions {
javaParameters = true
}
}
For Kotlin
Here’s how you can set the Kotlin compiler option javaParameters = true
in three different build systems, using the tab format you specified:
pom.xml build.gradle build.gradle.kts
Copy <build>
<plugins>
<plugin>
<groupId>org.jetbrains.kotlin</groupId>
<artifactId>kotlin-maven-plugin</artifactId>
<!-- ... your configuration here ... -->
<configuration>
<args>
<arg>-java-parameters</arg>
</args>
</configuration>
</plugin>
</plugins>
</build>
Copy kotlin {
compilerOptions {
javaParameters = true
}
}
Copy kotlin {
compilerOptions {
javaParameters = true
}
}
Last updated 5 months ago