Brigadier

From Minecraft Wiki
Jump to: navigation, search
Information icon.svg
This feature is exclusive to Java Edition.
Brigadier
Latest version

1.0.17

GitHub repository

brigadier

Written in

Java

Author

Mojang Studios

License

MIT License

Nathan Adams Mojang avatar.png

I'm so proud of that name! Brigadier is the name of the command engine that Minecraft uses.

Dinnerbone on Brigadier[1]

Brigadier is a command parser and dispatcher, designed and developed for Java Edition,[2] mainly maintained by Dinnerbone.[3] It is the first library used by Java Edition that Mojang has released under an open-source license.[4]

Usage[edit]

Brigadier is used for parsing and executing string commands.

Features[edit]

  • Define command nodes with argument or literal branches
  • Modify/fork command source in command contexts
  • Active inspection on command parsing[6]
  • Listing all possible commands from current command node[7]
  • Handle command result real-time on execution success/failure
  • Recursive command node redirection
    • /execute run redirects to the root node of the vanilla command dispatcher

History[edit]

October 25, 2014Dinnerbone mentions Brigadier in the comments on MC-10880.
July 27, 2017Dinnerbone discloses a non-obfuscated command parser library called "brigadier".
Java Edition
1.1317w45aCommands are now handled with Brigadier.
Minecraft introduces Brigadier as a dependency.
September 26, 2018Brigadier is open sourced under the MIT License.[8]
1.1419w08aAllows single quotes for strings in commands.[9]

Limitations[edit]

Brigadier and the older command library (before Java Edition 1.13 snapshot 17w45a) is not reliable as the hack-mastering-like library (like Java source code modifications for cheats-only usage or future hard-coded command library). Brigadier has some limitations for some commands like /enchant <player> minecraft:sharpness 12, /effect <player> minecraft:speed 2147483647 resulting in execution failure, but the further future command libraries other than Brigadier will be worked even further functionally without any limitations.

Due to the bug in Brigadier, command suggestions reports "Incorrect argument" with a trailing whitespace without suggestions (MC-165562), and command syntax checks unnecessary whitespaces (i.e. extraneous whitespaces and trailing whitespaces), etc. In fact, the leading whitespaces, extraneous slashes, and whitespaces between commands (e.g. /help, //gamerule, / experience) should also be ignored before command names, if these issues are fixed.

In some commands (mostly like /time, /worldborder), Brigadier still use 32-bit IEEE floating-point for certain arguments redundantly, which can cause the great numeric imprecision and range limitations.

For the further future command library other than Brigadier, the command syntax should use a punctuation marks like semicolon (;) for executing multiple commands at once, commas (,) for separating command arguments rather than whitespaces, and so on. In fact, the command library must be case-sensitive, especially for defining similar variables with different capitalization and the player names.

Gallery[edit]


References[edit]