You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
Precursor work for #483
Notable changes:
- No more flattening everything into a CommandAPICommand
- CommandTrees are not flattened
- CommandMetaData and Execution removed (only used to flatten CommandTrees)
- MultiLiteralArgument and subcommands are no longer converted into LiteralArguments
- Optional arguments are not chopped up into multiple arrays
- In general, a single call to `ExecutableCommand#register` now creates the entire Brigadier tree for that command instance
- Should only be converting Arguments to Brigadier nodes once instead of multiple times
- CommandAPIHandler no longer creates Brigadier nodes
- Delegated to AbstractCommandAPICommand, AbstractCommandTree, AbstractArgumentTree.java, and AbstractArgument
- Problems that prevent a command from being registered have been unified under CommandRegistrationException
- Exception messages tweaked
- Bukkit-specific features removed from `commandapi-core`
- Removed `isConverted` property of CommandAPICommand
- Moved logic for flattening EntitySelectorArgument from `CommandAPIHandler#generateBrigadierCommand` to Converter
- Moved special Bukkit command permission stuff into CommandAPIBukkit
- Taking advantage of Brigadier redirects
- Command alias nodes redirect to main command name
- MultiLiteralArgument literal nodes use redirects
- Instead of duplicating the argument node structure after these arguments, they can reference the same path
TODO:
- The checks performed by `CommandAPIHandler#hasCommandConflict` have not been reimplemented (I'm not sure if they did anything?)
- MultiLiteralArgument is currently broken. See Mojang/brigadier#137
- Many changes not covered by tests (could be sneaky behavioral differences)
0 commit comments