2018-08-21 06:35:30 +08:00
<?xml version="1.0" encoding="UTF-8" ?>
2023-03-01 08:44:37 +08:00
<class name= "Expression" inherits= "RefCounted" version= "4.1" xmlns:xsi= "http://www.w3.org/2001/XMLSchema-instance" xsi:noNamespaceSchemaLocation= "../class.xsd" >
2018-08-21 06:35:30 +08:00
<brief_description >
2018-10-31 23:37:10 +08:00
A class that stores an expression you can execute.
2018-08-21 06:35:30 +08:00
</brief_description>
<description >
2018-10-31 23:37:10 +08:00
An expression can be made of any arithmetic operation, built-in math function call, method call of a passed instance, or built-in type construction call.
2020-08-02 05:39:22 +08:00
An example expression text using the built-in math functions could be [code]sqrt(pow(3, 2) + pow(4, 2))[/code].
2018-10-31 23:37:10 +08:00
In the following example we use a [LineEdit] node to write our expression and show the result.
2020-09-13 20:45:36 +08:00
[codeblocks]
[gdscript]
var expression = Expression.new()
2018-10-31 23:37:10 +08:00
func _ready():
2022-10-30 07:56:46 +08:00
$LineEdit.text_submitted.connect(self._on_text_submitted)
2018-10-31 23:37:10 +08:00
2021-06-17 00:43:34 +08:00
func _on_text_submitted(command):
2020-09-13 20:45:36 +08:00
var error = expression.parse(command)
2018-10-31 23:37:10 +08:00
if error != OK:
2019-01-29 05:38:13 +08:00
print(expression.get_error_text())
2018-10-31 23:37:10 +08:00
return
2020-09-13 20:45:36 +08:00
var result = expression.execute()
2018-10-31 23:37:10 +08:00
if not expression.has_execute_failed():
$LineEdit.text = str(result)
2020-09-13 20:45:36 +08:00
[/gdscript]
[csharp]
2023-02-01 01:21:09 +08:00
private Expression _expression = new Expression();
2020-09-13 20:45:36 +08:00
public override void _Ready()
{
2022-08-26 22:21:45 +08:00
GetNode< LineEdit> ("LineEdit").TextSubmitted += OnTextEntered;
2020-09-13 20:45:36 +08:00
}
private void OnTextEntered(string command)
{
2023-02-01 01:21:09 +08:00
Error error = _expression.Parse(command);
2020-09-13 20:45:36 +08:00
if (error != Error.Ok)
{
2023-02-01 01:21:09 +08:00
GD.Print(_expression.GetErrorText());
2020-09-13 20:45:36 +08:00
return;
}
2023-02-01 01:21:09 +08:00
Variant result = _expression.Execute();
if (!_expression.HasExecuteFailed())
2020-09-13 20:45:36 +08:00
{
GetNode< LineEdit> ("LineEdit").Text = result.ToString();
}
}
[/csharp]
[/codeblocks]
2018-08-21 06:35:30 +08:00
</description>
<tutorials >
2023-04-26 17:58:13 +08:00
<link title= "Evaluating Expressions" > $DOCS_URL/tutorials/scripting/evaluating_expressions.html</link>
2018-08-21 06:35:30 +08:00
</tutorials>
<methods >
<method name= "execute" >
2021-07-30 21:28:05 +08:00
<return type= "Variant" />
2022-08-07 02:11:48 +08:00
<param index= "0" name= "inputs" type= "Array" default= "[]" />
<param index= "1" name= "base_instance" type= "Object" default= "null" />
<param index= "2" name= "show_error" type= "bool" default= "true" />
<param index= "3" name= "const_calls_only" type= "bool" default= "false" />
2018-08-21 06:35:30 +08:00
<description >
2018-10-31 23:37:10 +08:00
Executes the expression that was previously parsed by [method parse] and returns the result. Before you use the returned object, you should check if the method failed by calling [method has_execute_failed].
2019-01-31 22:44:29 +08:00
If you defined input variables in [method parse], you can specify their values in the inputs array, in the same order.
2018-08-21 06:35:30 +08:00
</description>
</method>
<method name= "get_error_text" qualifiers= "const" >
2021-07-30 21:28:05 +08:00
<return type= "String" />
2018-08-21 06:35:30 +08:00
<description >
2023-02-27 02:17:05 +08:00
Returns the error text if [method parse] or [method execute] has failed.
2018-08-21 06:35:30 +08:00
</description>
</method>
<method name= "has_execute_failed" qualifiers= "const" >
2021-07-30 21:28:05 +08:00
<return type= "bool" />
2018-08-21 06:35:30 +08:00
<description >
2018-10-31 23:37:10 +08:00
Returns [code]true[/code] if [method execute] has failed.
2018-08-21 06:35:30 +08:00
</description>
</method>
<method name= "parse" >
2021-07-30 21:28:05 +08:00
<return type= "int" enum= "Error" />
2022-08-07 02:11:48 +08:00
<param index= "0" name= "expression" type= "String" />
<param index= "1" name= "input_names" type= "PackedStringArray" default= "PackedStringArray()" />
2018-08-21 06:35:30 +08:00
<description >
2019-06-27 19:24:03 +08:00
Parses the expression and returns an [enum Error] code.
2022-08-13 00:07:53 +08:00
You can optionally specify names of variables that may appear in the expression with [param input_names], so that you can bind them when it gets executed.
2018-08-21 06:35:30 +08:00
</description>
</method>
</methods>
</class>