Engine:CCMD varedit: Difference between revisions

From AddOn Studio
Jump to navigation Jump to search
Line 52: Line 52:


=== Change if exists ===
=== Change if exists ===
In this case lets pretend 'bob' is a Client module variable, placed in the 'global' context the client service is started.
In this case lets pretend 'bob' is a Client module variable. Client when started will create 'bob' with a default value in the 'global' context.
*  Variable 'bob' doesn't exist, and 'bob' is not the name of anything else.
*  Variable 'bob' doesn't exist, and 'bob' is not the name of anything else.
<kua>
<kua>

Revision as of 03:34, 14 October 2023

Console commands

Sets an existing variable in the current context, reports variable value.

bob fred

Associations

  • Is the default command for the 'global' context.
  • Does not have its own command name in 'global' for console or script.

Arguments

  • name - name for variable to set
  • value (optional) - the value to set. If no value, then prints value if exists.

Details

Can be used to set or report a value for an existing variable. Will fail if variable does not already exist.

This command behaves like a combination of 'var' and 'set', but will never create a variable:

  • varedit - never creates, sets anytime value exists
  • var - creates and sets only if not exist
  • set - creates and sets any time

While 'varedit' is intended make console variable checking and editing easy, in combination with the other variable commands, can allow scripts and other types of macros to avoid lots of situations where complex logic would otherwise be required.

For example, this default command 'varedit' would allow writing a script that was intended to only set certain variables if another service or module had already created them.

Examples

Default values

  • 'bob' without a value. Variable 'bob' doesn't exist, and 'bob' is not the name of anything else.
> bob
Unknown: bob
  • Tries to set variable 'bob' to 'fred'. Fails as 'bob' does not exist.
> bob fred
Unknown: bob
  • Using the 'set' command to create the variable 'bob' and set to 'fred'.
> set bob fred
  • Same as the first example, but now 'bob' exists.
> bob
'bob' is 'fred'
  • Try to set existing 'bob' to 'james', value changes.
> bob james
> bob
'bob' is 'james'

Change if exists

In this case lets pretend 'bob' is a Client module variable. Client when started will create 'bob' with a default value in the 'global' context.

  • Variable 'bob' doesn't exist, and 'bob' is not the name of anything else.
> bob
Unknown: bob
  • Tries to set variable 'bob' to 'fred'. Fails as 'bob' does not exist. Which is good.
> bob fred
Unknown: bob
  • Using the 'client' context run the Client 'start' command which will create the variable 'bob' with a default value of '8080'.
> client start
  • Same as the first example, but now 'bob' exists.
> bob
'bob' is '8080'
  • Try to set existing 'bob' to '8081', value changes.
> bob 8081
> bob
'bob' is '8081'

Notes