io.github.freya022.botcommands.api.commands.annotations.Optional.kt Maven / Gradle / Ivy
package io.github.freya022.botcommands.api.commands.annotations
import io.github.freya022.botcommands.api.commands.application.slash.annotations.SlashOption
import io.github.freya022.botcommands.api.commands.text.annotations.TextOption
import org.jetbrains.annotations.Nullable
/**
* Marks an option ([@SlashOption][SlashOption] or [@TextOption][TextOption]) as being optional.
*
* **Note**: Kotlin users are not required to use this annotation, using `?` is enough.
*
* I recommend using [@Nullable][Nullable] annotation instead, to benefit from nullability analysis.
*
* **Note for text commands:** Take care with this annotation, you might have errors if your command is considered too complex.
* Several factors can increase the chance of a command being unusable, such as
* - Too many optionals
* - Options with a dynamic number of spaces (such as strings)
*
* Attempts at fixing the issue can include moving the parameters around, like avoiding 2 strings next to each other.
*/
@Target(AnnotationTarget.VALUE_PARAMETER)
@Retention(AnnotationRetention.RUNTIME)
annotation class Optional
© 2015 - 2025 Weber Informatics LLC | Privacy Policy