RU/addCommandHandler: Difference between revisions
m (prefer normal note) |
|||
Line 1: | Line 1: | ||
__NOTOC__ | __NOTOC__ | ||
{{RU/Server client function}} | {{RU/Server client function}} | ||
{{ | {{note|Строгая рекомендация, не использовать имя функции заголовка, в качестве имени команды,т.к. это может привести к неразберихе, если множество функций будет использовано с одной командой. Используйте имя описывающее цель вашего заголовка.}} | ||
Эта функция привязывает функцию скриптинга(заголовок) к консольной команде, что-бы при её вводе игроком или администратором, функция вызывалась. | Эта функция привязывает функцию скриптинга(заголовок) к консольной команде, что-бы при её вводе игроком или администратором, функция вызывалась. | ||
'''Note:''' Вы не можете использовать "list" или "test" в качестве имени команды. | '''Note:''' Вы не можете использовать "list" или "test" в качестве имени команды. |
Latest revision as of 08:44, 7 September 2019
Эта функция привязывает функцию скриптинга(заголовок) к консольной команде, что-бы при её вводе игроком или администратором, функция вызывалась. Note: Вы не можете использовать "list" или "test" в качестве имени команды.
Множество командных заголовков может быть привязано к одной команде, и они будут вызваны в порядке в котором привязаны заголовки. Равно как и множество команд может иметь заголовок одной функции, и параметр commandName используется для решения хода действий.
Для пользователей, команда будет в следующем формате:
commandName argument1 argument2
Это может быть инициировано, с помощью консоли или чата(через /). Для заголовков серверной стороны, админ сервера имеет возможность инициировать это из консоли сервера, от имени консоли игрока.
Синтаксис
bool addCommandHandler ( string commandName, function handlerFunction, [bool restricted = false, bool caseSensitive = true] )
Required Arguments
- commandName: This is the name of the command you wish to attach a handler to. This is what must be typed into the console to trigger the function.
- handlerFunction: This is the function that you want the command to trigger, which has to be defined before you add the handler. This function can take two parameters, playerSource and commandName, followed by as many parameters you expect after your command (see below). These are all optional.
Optional Arguments
NOTE: When using optional arguments, you might need to supply all arguments before the one you wish to use. For more information on optional arguments, see optional arguments.
- restricted: Specify whether or not this command should be restricted by default. Use this on commands that should be inaccessible to everyone as default except special users specified in the ACL (Access Control List). This is to make sure admin commands such as ie. 'punish' won't be available to everyone if a server administrator forgets masking it in ACL. Make sure to add the command to your ACL under the proper group for it to be usefull (i.e <right name="command.killEveryone" access="true"></right>). This argument defaults to false if nothing is specified.
- caseSensitive: Specifies if the command handler will ignore the case for this command name.
bool addCommandHandler ( string commandName, function handlerFunction, [bool caseSensitive = true] )
Required Arguments
- commandName: This is the name of the command you wish to attach a handler to. This is what must be typed into the console to trigger the function.
- handlerFunction: This is the function that you want the command to trigger, which has to be defined before you add the handler. This function can take two parameters, playerSource and commandName, followed by as many parameters you expect after your command (see below). These are all optional.
Optional Arguments
NOTE: When using optional arguments, you might need to supply all arguments before the one you wish to use. For more information on optional arguments, see optional arguments.
- caseSensitive: Specifies if the command handler will ignore the case for this command name.
Handler function parameters
These are the parameters for the handler function that is called when the command is used.
player playerSource, string commandName, [string arg1, string arg2, ...]
- playerSource: The player who triggered the command. If not triggered by a player (e.g. by admin), this will be false.
- commandName: The name of the command triggered. This is useful if multiple commands go through one function.
- arg1, arg2, ...: Each word after command name in the original command is passed here in a seperate variable. If there is no value for an argument, its variable will contain nil. You can deal with a variable number of arguments using the vararg expression, as shown in Server Example 2 below.
string commandName, [string arg1, string arg2, ...]
- commandName: The name of the command triggered. This is useful if multiple commands go through one function.
- arg1, arg2, ...: Each word after command name in the original command is passed here in a seperate variable. If there is no value for an argument, its variable will contain nil. You can deal with a variable number of arguments using the vararg expression, as shown in Server Example 2 below.
Returns
Returns true if the command handler was added successfully, false otherwise.
Examples
Example 1: This example defines a command handler for the command createmarker. This will create a red marker at the position of the player player who uses it.
-- Define our function that will handle this command function consoleCreateMarker ( playerSource ) -- If a player triggered it (rather than the admin) then if ( playerSource ) then -- Get that player's position local x, y, z = getElementPosition ( playerSource ) -- Create a size 2, red checkpoint marker at their position createMarker ( x, y, z, "checkpoint", 2, 255, 0, 0, 255 ) -- Output it in his chat box outputChatBox ( "You got a red marker", playerSource ) end end -- Attach the 'consoleCreateMarker' function to the "createmarker" command addCommandHandler ( "createmarker", consoleCreateMarker )
See Also
- getMaxPlayers
- getServerConfigSetting
- getServerHttpPort
- getServerName
- getServerPassword
- getServerPort
- isGlitchEnabled
- setGlitchEnabled
- setMaxPlayers
- setServerConfigSetting
- setServerPassword
- shutdown