Skip to content

Latest commit

 

History

History
63 lines (57 loc) · 2.7 KB

README.md

File metadata and controls

63 lines (57 loc) · 2.7 KB

caturix-spigot

An adaptation of Caturix for Spigot.

A basic example (written in Kotlin):

import com.ironveilrp.caturix.spigot.common.CommonModule
import com.ironveilrp.caturix.spigot.common.CommandTarget
import com.ironveilrp.caturix.spigot.common.Toggle
import com.ironveilrp.caturix.spigot.common.bukkit.BukkitAuthorizer
import com.ironveilrp.caturix.spigot.common.bukkit.provider.BukkitModule
import com.ironveilrp.caturix.spigot.common.bukkit.provider.sender.BukkitSenderModule
import com.ironveilrp.caturix.spigot.common.bukkit.registerCommand
import com.ironveilrp.caturix.Intake
import com.ironveilrp.caturix.fluent.CommandGraph
import com.ironveilrp.caturix.parametric.ParametricBuilder
import com.ironveilrp.caturix.parametric.provider.PrimitivesModule
import com.ironveilrp.caturix.Command
import com.ironveilrp.caturix.Require
import org.bukkit.entity.Player
import org.bukkit.plugin.java.JavaPlugin

class MyPlugin : JavaPlugin() {
    override fun onEnable() {
        val injector = Intake.createInjector()
        injector.install(PrimitivesModule())
        injector.install(BukkitModule(server))
        injector.install(BukkitSenderModule())
        injector.install(CommonModule())

        val builder = ParametricBuilder(injector)
        builder.authorizer = BukkitAuthorizer()

        val dispatcher = CommandGraph()
                .builder(builder)
                .commands()
                .registerMethods(MyCommands())
                .graph()
                .dispatcher

        registerCommand(dispatcher, this, dispatcher.aliases.toList())
    }
}

class MyCommands {
    @Command(aliases = ["mycommand", "mc"], desc = "Toggle my command")
    @Require("mypermission")
    fun mycommand(@Toggle value: Boolean, @CommandTarget("mycommand.others") target: Player) {
        // value is a boolean, but instead of the usual true/false,
        // it is called using on/off in the command, by the @Toggle
        // so you call this command like `mycommand on` or `mycommand off`
        //
        // The @CommandTarget target: Player with the associated permission will
        // be the command sender himself, or optionally, if the command sender has the
        // associated permission *and* has specified another player,
        // the specified player. Like as follows:
        // `mycommand on SomePlayername`, `mycommand off SomePlayername`
        //
        // for more in-depth explanation and examples of how to use Intake in
        // general, of course, see the Intake documentation.
        // ...
    }
}