From 8c3c7d67fec307fddcb9f86b62800d825f4c819e Mon Sep 17 00:00:00 2001 From: walterhiggins Date: Sat, 14 Jun 2014 15:46:07 +0100 Subject: [PATCH] tab-completion using a callback --- src/main/js/lib/scriptcraft.js | 13 ++++++++++++- 1 file changed, 12 insertions(+), 1 deletion(-) diff --git a/src/main/js/lib/scriptcraft.js b/src/main/js/lib/scriptcraft.js index 9b1429588..7369e6cb0 100644 --- a/src/main/js/lib/scriptcraft.js +++ b/src/main/js/lib/scriptcraft.js @@ -301,7 +301,7 @@ The `command()` function is used to expose javascript functions for use by non-o * params : An Array of type String - the list of parameters passed to the command. * sender : The [CommandSender][bukcs] object that invoked the command (this is usually a Player object but can be a Block ([BlockCommandSender][bukbcs]). - * options (Array - optional) : An array of command options/parameters which the player can supply (It's useful to supply an array so that Tab-Completion works for the `/jsp ` commands. + * options (Array|Function - optional) : An array of command options/parameters which the player can supply (It's useful to supply an array so that Tab-Completion works for the `/jsp ` commands. If a function is supplied instead of an array then the function will be invoked at TAB-completion time and should return an array of strings. * intercepts (boolean - optional) : Indicates whether this command can intercept Tab-Completion of the `/jsp ` command - advanced usage - see alias/alias.js for example. #### Example @@ -316,6 +316,17 @@ The `command()` function is used to expose javascript functions for use by non-o /jsp boo Hi! > Hi! +To use a callback for options (TAB-Completion) ... + + + function boo( params, sender ) { + var receiver = server.getPlayer( params[0] ); + if ( receiver ){ + receiver.sendMessage( sender.name + ' says boo!'); + } + } + command( boo, bukkit.playerNames ); + See chat/colors.js or alias/alias.js or homes/homes.js for more examples of how to use the `command()` function. ### setTimeout() function