Merge pull request #23422 from santouits/docs-expression
Docs: Expression class docs
This commit is contained in:
commit
a282e67b24
@ -1,8 +1,27 @@
|
|||||||
<?xml version="1.0" encoding="UTF-8" ?>
|
<?xml version="1.0" encoding="UTF-8" ?>
|
||||||
<class name="Expression" inherits="Reference" category="Core" version="3.1">
|
<class name="Expression" inherits="Reference" category="Core" version="3.1">
|
||||||
<brief_description>
|
<brief_description>
|
||||||
|
A class that stores an expression you can execute.
|
||||||
</brief_description>
|
</brief_description>
|
||||||
<description>
|
<description>
|
||||||
|
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.
|
||||||
|
An example expression text using the built-in math functions could be [code]sqrt(pow(3,2) + pow(4,2))[/code].
|
||||||
|
In the following example we use a [LineEdit] node to write our expression and show the result.
|
||||||
|
[codeblock]
|
||||||
|
onready var expression = Expression.new()
|
||||||
|
|
||||||
|
func _ready():
|
||||||
|
$LineEdit.connect("text_entered", self, "_on_text_entered")
|
||||||
|
|
||||||
|
func _on_text_entered(command):
|
||||||
|
var error = expression.parse(command, [])
|
||||||
|
if error != OK:
|
||||||
|
print(get_error_text())
|
||||||
|
return
|
||||||
|
var result = expression.execute([], null, true)
|
||||||
|
if not expression.has_execute_failed():
|
||||||
|
$LineEdit.text = str(result)
|
||||||
|
[/codeblock]
|
||||||
</description>
|
</description>
|
||||||
<tutorials>
|
<tutorials>
|
||||||
</tutorials>
|
</tutorials>
|
||||||
@ -19,18 +38,21 @@
|
|||||||
<argument index="2" name="show_error" type="bool" default="true">
|
<argument index="2" name="show_error" type="bool" default="true">
|
||||||
</argument>
|
</argument>
|
||||||
<description>
|
<description>
|
||||||
|
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].
|
||||||
</description>
|
</description>
|
||||||
</method>
|
</method>
|
||||||
<method name="get_error_text" qualifiers="const">
|
<method name="get_error_text" qualifiers="const">
|
||||||
<return type="String">
|
<return type="String">
|
||||||
</return>
|
</return>
|
||||||
<description>
|
<description>
|
||||||
|
Returns the error text if [method parse] has failed.
|
||||||
</description>
|
</description>
|
||||||
</method>
|
</method>
|
||||||
<method name="has_execute_failed" qualifiers="const">
|
<method name="has_execute_failed" qualifiers="const">
|
||||||
<return type="bool">
|
<return type="bool">
|
||||||
</return>
|
</return>
|
||||||
<description>
|
<description>
|
||||||
|
Returns [code]true[/code] if [method execute] has failed.
|
||||||
</description>
|
</description>
|
||||||
</method>
|
</method>
|
||||||
<method name="parse">
|
<method name="parse">
|
||||||
@ -41,6 +63,7 @@
|
|||||||
<argument index="1" name="input_names" type="PoolStringArray" default="PoolStringArray( )">
|
<argument index="1" name="input_names" type="PoolStringArray" default="PoolStringArray( )">
|
||||||
</argument>
|
</argument>
|
||||||
<description>
|
<description>
|
||||||
|
Parses the expression and returns a [enum @GlobalScope.Error].
|
||||||
</description>
|
</description>
|
||||||
</method>
|
</method>
|
||||||
</methods>
|
</methods>
|
||||||
|
Loading…
Reference in New Issue
Block a user