2017-09-12 22:42:36 +02:00
<?xml version="1.0" encoding="UTF-8" ?>
2022-02-14 14:18:53 +01:00
<class name= "@GDScript" version= "4.0" xmlns:xsi= "http://www.w3.org/2001/XMLSchema-instance" xsi:noNamespaceSchemaLocation= "../../../doc/class.xsd" >
2017-09-12 22:42:36 +02:00
<brief_description >
Built-in GDScript functions.
</brief_description>
<description >
2021-11-25 12:24:09 +01:00
A list of GDScript-specific utility functions accessed in any script.
For the list of the global functions and constants see [@GlobalScope].
2017-09-12 22:42:36 +02:00
</description>
<tutorials >
</tutorials>
<methods >
<method name= "Color8" >
2021-07-30 15:28:05 +02:00
<return type= "Color" />
<argument index= "0" name= "r8" type= "int" />
<argument index= "1" name= "g8" type= "int" />
<argument index= "2" name= "b8" type= "int" />
<argument index= "3" name= "a8" type= "int" default= "255" />
2017-09-12 22:42:36 +02:00
<description >
2019-11-02 09:48:08 +01:00
Returns a color constructed from integer red, green, blue, and alpha channels. Each channel should have 8 bits of information ranging from 0 to 255.
2017-09-18 00:36:34 +02:00
[code]r8[/code] red channel
[code]g8[/code] green channel
[code]b8[/code] blue channel
[code]a8[/code] alpha channel
2017-09-12 22:42:36 +02:00
[codeblock]
red = Color8(255, 0, 0)
[/codeblock]
</description>
</method>
<method name= "assert" >
2021-07-30 15:28:05 +02:00
<return type= "void" />
<argument index= "0" name= "condition" type= "bool" />
<argument index= "1" name= "message" type= "String" default= """" />
2017-09-12 22:42:36 +02:00
<description >
2021-01-04 14:33:44 +01:00
Asserts that the [code]condition[/code] is [code]true[/code]. If the [code]condition[/code] is [code]false[/code], an error is generated. When running from the editor, the running project will also be paused until you resume it. This can be used as a stronger form of [method @GlobalScope.push_error] for reporting errors to project developers or add-on users.
2020-11-09 21:48:24 +01:00
[b]Note:[/b] For performance reasons, the code inside [method assert] is only executed in debug builds or when running the project from the editor. Don't include code that has side effects in an [method assert] call. Otherwise, the project will behave differently when exported in release mode.
2020-03-31 10:39:23 +02:00
The optional [code]message[/code] argument, if given, is shown in addition to the generic "Assertion failed" message. You can use this to provide additional details about why the assertion failed.
2017-09-13 08:18:51 +02:00
[codeblock]
2020-11-09 21:48:24 +01:00
# Imagine we always want speed to be between 0 and 20.
var speed = -10
2019-06-03 12:27:37 +02:00
assert(speed < 20) # True, the program will continue
assert(speed > = 0) # False, the program will stop
2020-11-09 21:48:24 +01:00
assert(speed > = 0 and speed < 20) # You can also combine the two conditional statements in one check
2020-03-31 10:39:23 +02:00
assert(speed < 20, "speed = %f, but the speed limit is 20" % speed) # Show a message with clarifying details
2017-09-13 08:18:51 +02:00
[/codeblock]
2017-09-12 22:42:36 +02:00
</description>
</method>
<method name= "char" >
2021-07-30 15:28:05 +02:00
<return type= "String" />
<argument index= "0" name= "char" type= "int" />
2017-09-12 22:42:36 +02:00
<description >
2019-12-15 04:10:29 +01:00
Returns a character as a String of the given Unicode code point (which is compatible with ASCII code).
2017-09-12 22:42:36 +02:00
[codeblock]
2019-06-22 01:04:47 +02:00
a = char(65) # a is "A"
a = char(65 + 32) # a is "a"
2019-12-15 04:10:29 +01:00
a = char(8364) # a is "€"
2017-09-12 22:42:36 +02:00
[/codeblock]
</description>
</method>
<method name= "convert" >
2021-07-30 15:28:05 +02:00
<return type= "Variant" />
<argument index= "0" name= "what" type= "Variant" />
<argument index= "1" name= "type" type= "int" />
2017-09-12 22:42:36 +02:00
<description >
2019-12-06 23:09:20 +01:00
Converts from a type to another in the best way possible. The [code]type[/code] parameter uses the [enum Variant.Type] values.
2017-09-12 22:42:36 +02:00
[codeblock]
a = Vector2(1, 0)
2019-06-22 01:04:47 +02:00
# Prints 1
2017-09-12 22:42:36 +02:00
print(a.length())
a = convert(a, TYPE_STRING)
2019-06-22 01:04:47 +02:00
# Prints 6 as "(1, 0)" is 6 characters
2017-09-12 22:42:36 +02:00
print(a.length())
[/codeblock]
</description>
</method>
<method name= "dict2inst" >
2021-07-30 15:28:05 +02:00
<return type= "Object" />
<argument index= "0" name= "dictionary" type= "Dictionary" />
2017-09-12 22:42:36 +02:00
<description >
2020-11-29 15:08:45 +01:00
Converts a dictionary (previously created with [method inst2dict]) back to an instance. Useful for deserializing.
2017-09-12 22:42:36 +02:00
</description>
</method>
2018-07-26 11:56:21 +02:00
<method name= "get_stack" >
2021-07-30 15:28:05 +02:00
<return type= "Array" />
2018-07-26 11:56:21 +02:00
<description >
2019-01-06 13:57:23 +01:00
Returns an array of dictionaries representing the current call stack.
[codeblock]
func _ready():
foo()
func foo():
bar()
func bar():
print(get_stack())
[/codeblock]
would print
[codeblock]
[{function:bar, line:12, source:res://script.gd}, {function:foo, line:9, source:res://script.gd}, {function:_ready, line:6, source:res://script.gd}]
[/codeblock]
2021-11-01 04:06:57 +01:00
[b]Note:[/b] Not supported for calling from threads. Instead, this will return an empty array.
2018-07-26 11:56:21 +02:00
</description>
</method>
2017-09-12 22:42:36 +02:00
<method name= "inst2dict" >
2021-07-30 15:28:05 +02:00
<return type= "Dictionary" />
<argument index= "0" name= "instance" type= "Object" />
2017-09-12 22:42:36 +02:00
<description >
2017-09-18 00:36:34 +02:00
Returns the passed instance converted to a dictionary (useful for serializing).
2017-09-12 22:42:36 +02:00
[codeblock]
var foo = "bar"
func _ready():
var d = inst2dict(self)
print(d.keys())
print(d.values())
[/codeblock]
Prints out:
[codeblock]
[@subpath, @path, foo]
[, res://test.gd, bar]
[/codeblock]
</description>
</method>
<method name= "len" >
2021-07-30 15:28:05 +02:00
<return type= "int" />
<argument index= "0" name= "var" type= "Variant" />
2017-09-12 22:42:36 +02:00
<description >
2018-07-28 22:44:58 +02:00
Returns length of Variant [code]var[/code]. Length is the character count of String, element count of Array, size of Dictionary, etc.
[b]Note:[/b] Generates a fatal error if Variant can not provide a length.
2017-09-12 22:42:36 +02:00
[codeblock]
a = [1, 2, 3, 4]
2019-06-22 01:04:47 +02:00
len(a) # Returns 4
2017-09-12 22:42:36 +02:00
[/codeblock]
</description>
</method>
<method name= "load" >
2021-07-30 15:28:05 +02:00
<return type= "Resource" />
<argument index= "0" name= "path" type= "String" />
2017-09-12 22:42:36 +02:00
<description >
2020-06-28 20:51:46 +02:00
Loads a resource from the filesystem located at [code]path[/code]. The resource is loaded on the method call (unless it's referenced already elsewhere, e.g. in another script or in the scene), which might cause slight delay, especially when loading scenes. To avoid unnecessary delays when loading something multiple times, either store the resource in a variable or use [method preload].
[b]Note:[/b] Resource paths can be obtained by right-clicking on a resource in the FileSystem dock and choosing "Copy Path" or by dragging the file from the FileSystem dock into the script.
2017-09-12 22:42:36 +02:00
[codeblock]
2020-06-28 20:51:46 +02:00
# Load a scene called main located in the root of the project directory and cache it in a variable.
var main = load("res://main.tscn") # main will contain a PackedScene resource.
2017-09-12 22:42:36 +02:00
[/codeblock]
2019-12-11 21:14:58 +01:00
[b]Important:[/b] The path must be absolute, a local path will just return [code]null[/code].
2020-09-30 22:03:36 +02:00
This method is a simplified version of [method ResourceLoader.load], which can be used for more advanced scenarios.
2022-06-07 21:29:39 +02:00
[b]Note:[/b] You have to import the files into the engine first to load them using [method load]. If you want to load [Image]s at run-time, you may use [method Image.load]. If you want to import audio files, you can use the snippet described in [member AudioStreamMP3.data].
2017-09-12 22:42:36 +02:00
</description>
</method>
2021-01-04 14:33:44 +01:00
<method name= "preload" >
2021-07-30 15:28:05 +02:00
<return type= "Resource" />
<argument index= "0" name= "path" type= "String" />
2017-09-12 22:42:36 +02:00
<description >
2021-01-04 14:33:44 +01:00
Returns a [Resource] from the filesystem located at [code]path[/code]. The resource is loaded during script parsing, i.e. is loaded with the script and [method preload] effectively acts as a reference to that resource. Note that the method requires a constant path. If you want to load a resource from a dynamic/variable path, use [method load].
[b]Note:[/b] Resource paths can be obtained by right clicking on a resource in the Assets Panel and choosing "Copy Path" or by dragging the file from the FileSystem dock into the script.
2017-09-12 22:42:36 +02:00
[codeblock]
2021-01-04 14:33:44 +01:00
# Instance a scene.
2021-06-18 00:03:09 +02:00
var diamond = preload("res://diamond.tscn").instantiate()
2017-09-12 22:42:36 +02:00
[/codeblock]
</description>
</method>
2021-01-04 14:33:44 +01:00
<method name= "print_debug" qualifiers= "vararg" >
2021-07-30 15:28:05 +02:00
<return type= "void" />
2017-09-12 22:42:36 +02:00
<description >
2021-11-01 04:06:57 +01:00
Like [method @GlobalScope.print], but includes the current stack frame when running with the debugger turned on.
Output in the console would look something like this:
[codeblock]
Test print
At: res://test.gd:15:_process()
[/codeblock]
[b]Note:[/b] Not supported for calling from threads. Instead of the stack frame, this will print the thread ID.
2017-09-12 22:42:36 +02:00
</description>
</method>
2021-01-04 14:33:44 +01:00
<method name= "print_stack" >
2021-07-30 15:28:05 +02:00
<return type= "void" />
2017-09-12 22:42:36 +02:00
<description >
2021-11-01 04:06:57 +01:00
Prints a stack trace at the current code location. Only works when running with debugger turned on.
2021-01-04 14:33:44 +01:00
Output in the console would look something like this:
2017-09-12 22:42:36 +02:00
[codeblock]
2021-01-04 14:33:44 +01:00
Frame 0 - res://test.gd:16 in function '_process'
2017-09-12 22:42:36 +02:00
[/codeblock]
2021-11-01 04:06:57 +01:00
[b]Note:[/b] Not supported for calling from threads. Instead of the stack trace, this will print the thread ID.
2017-09-12 22:42:36 +02:00
</description>
</method>
2021-01-04 14:33:44 +01:00
<method name= "range" qualifiers= "vararg" >
2021-07-30 15:28:05 +02:00
<return type= "Array" />
2017-09-12 22:42:36 +02:00
<description >
2022-04-14 05:07:29 +02:00
Returns an array with the given range. [method range] can be called in three ways:
[code]range(n: int)[/code]: Starts from 0, increases by steps of 1, and stops [i]before[/i] [code]n[/code]. The argument [code]n[/code] is [b]exclusive[/b].
[code]range(b: int, n: int)[/code]: Starts from [code]b[/code], increases by steps of 1, and stops [i]before[/i] [code]n[/code]. The arguments [code]b[/code] and [code]n[/code] are [b]inclusive[/b] and [b]exclusive[/b], respectively.
[code]range(b: int, n: int, s: int)[/code]: Starts from [code]b[/code], increases/decreases by steps of [code]s[/code], and stops [i]before[/i] [code]n[/code]. The arguments [code]b[/code] and [code]n[/code] are [b]inclusive[/b] and [b]exclusive[/b], respectively. The argument [code]s[/code] [b]can[/b] be negative, but not [code]0[/code]. If [code]s[/code] is [code]0[/code], an error message is printed.
[method range] converts all arguments to [int] before processing.
[b]Note:[/b] Returns an empty array if no value meets the value constraint (e.g. [code]range(2, 5, -1)[/code] or [code]range(5, 5, 1)[/code]).
Examples:
[codeblock]
print(range(4)) # Prints [0, 1, 2, 3]
print(range(2, 5)) # Prints [2, 3, 4]
print(range(0, 6, 2)) # Prints [0, 2, 4]
print(range(4, 1, -1)) # Prints [4, 3, 2]
2017-09-13 08:18:51 +02:00
[/codeblock]
2020-05-01 21:31:45 +02:00
To iterate over an [Array] backwards, use:
[codeblock]
var array = [3, 6, 9]
2022-04-14 05:07:29 +02:00
for i in range(array.size(), 0, -1):
print(array[i - 1])
2020-05-01 21:31:45 +02:00
[/codeblock]
Output:
[codeblock]
9
6
3
[/codeblock]
2022-02-18 00:48:33 +01:00
To iterate over [float], convert them in the loop.
[codeblock]
for i in range (3, 0, -1):
print(i / 10.0)
[/codeblock]
Output:
[codeblock]
0.3
0.2
0.1
[/codeblock]
2017-09-12 22:42:36 +02:00
</description>
</method>
<method name= "str" qualifiers= "vararg" >
2021-07-30 15:28:05 +02:00
<return type= "String" />
2017-09-12 22:42:36 +02:00
<description >
2017-09-18 00:36:34 +02:00
Converts one or more arguments to string in the best way possible.
2017-09-13 08:18:51 +02:00
[codeblock]
var a = [10, 20, 30]
var b = str(a);
2019-06-22 01:04:47 +02:00
len(a) # Returns 3
len(b) # Returns 12
2017-09-13 08:18:51 +02:00
[/codeblock]
2017-09-12 22:42:36 +02:00
</description>
</method>
<method name= "type_exists" >
2021-07-30 15:28:05 +02:00
<return type= "bool" />
<argument index= "0" name= "type" type= "StringName" />
2017-11-04 17:09:37 +01:00
<description >
</description>
</method>
2017-09-12 22:42:36 +02:00
</methods>
<constants >
2019-12-23 16:38:33 +01:00
<constant name= "PI" value= "3.14159265358979" >
2021-07-22 08:36:14 +02:00
Constant that represents how many times the diameter of a circle fits around its perimeter. This is equivalent to [code]TAU / 2[/code], or 180 degrees in rotations.
2017-11-04 10:34:27 +01:00
</constant>
2019-12-23 16:38:33 +01:00
<constant name= "TAU" value= "6.28318530717959" >
2021-07-22 08:36:14 +02:00
The circle constant, the circumference of the unit circle in radians. This is equivalent to [code]PI * 2[/code], or 360 degrees in rotations.
2017-09-12 22:42:36 +02:00
</constant>
2017-11-24 23:16:30 +01:00
<constant name= "INF" value= "inf" >
2021-07-22 08:36:14 +02:00
Positive floating-point infinity. This is the result of floating-point division when the divisor is [code]0.0[/code]. For negative infinity, use [code]-INF[/code]. Dividing by [code]-0.0[/code] will result in negative infinity if the numerator is positive, so dividing by [code]0.0[/code] is not the same as dividing by [code]-0.0[/code] (despite [code]0.0 == -0.0[/code] returning [code]true[/code]).
[b]Note:[/b] Numeric infinity is only a concept with floating-point numbers, and has no equivalent for integers. Dividing an integer number by [code]0[/code] will not result in [constant INF] and will result in a run-time error instead.
2017-09-12 22:42:36 +02:00
</constant>
2018-06-13 14:42:55 +02:00
<constant name= "NAN" value= "nan" >
2021-07-22 08:36:14 +02:00
"Not a Number", an invalid floating-point value. [constant NAN] has special properties, including that it is not equal to itself ([code]NAN == NAN[/code] returns [code]false[/code]). It is output by some invalid operations, such as dividing floating-point [code]0.0[/code] by [code]0.0[/code].
[b]Note:[/b] "Not a Number" is only a concept with floating-point numbers, and has no equivalent for integers. Dividing an integer [code]0[/code] by [code]0[/code] will not result in [constant NAN] and will result in a run-time error instead.
2017-09-12 22:42:36 +02:00
</constant>
</constants>
2022-07-04 17:56:34 +02:00
<annotations >
<annotation name= "@export" >
<return type= "void" />
<description >
</description>
</annotation>
2022-07-06 16:37:40 +02:00
<annotation name= "@export_category" >
<return type= "void" />
<argument index= "0" name= "name" type= "String" />
<description >
</description>
</annotation>
2022-07-04 17:56:34 +02:00
<annotation name= "@export_color_no_alpha" >
<return type= "void" />
<description >
</description>
</annotation>
<annotation name= "@export_dir" >
<return type= "void" />
<description >
</description>
</annotation>
<annotation name= "@export_enum" qualifiers= "vararg" >
<return type= "void" />
<argument index= "0" name= "names" type= "String" />
<description >
</description>
</annotation>
2022-07-11 22:02:55 +02:00
<annotation name= "@export_exp_easing" qualifiers= "vararg" >
2022-07-04 17:56:34 +02:00
<return type= "void" />
2022-07-11 22:02:55 +02:00
<argument index= "0" name= "hints" type= "String" default= """" />
2022-07-04 17:56:34 +02:00
<description >
</description>
</annotation>
<annotation name= "@export_file" qualifiers= "vararg" >
<return type= "void" />
2022-07-11 22:02:55 +02:00
<argument index= "0" name= "filter" type= "String" default= """" />
2022-07-04 17:56:34 +02:00
<description >
</description>
</annotation>
<annotation name= "@export_flags" qualifiers= "vararg" >
<return type= "void" />
<argument index= "0" name= "names" type= "String" />
<description >
</description>
</annotation>
<annotation name= "@export_flags_2d_navigation" >
<return type= "void" />
<description >
</description>
</annotation>
<annotation name= "@export_flags_2d_physics" >
<return type= "void" />
<description >
</description>
</annotation>
<annotation name= "@export_flags_2d_render" >
<return type= "void" />
<description >
</description>
</annotation>
<annotation name= "@export_flags_3d_navigation" >
<return type= "void" />
<description >
</description>
</annotation>
<annotation name= "@export_flags_3d_physics" >
<return type= "void" />
<description >
</description>
</annotation>
<annotation name= "@export_flags_3d_render" >
<return type= "void" />
<description >
</description>
</annotation>
<annotation name= "@export_global_dir" >
<return type= "void" />
<description >
</description>
</annotation>
<annotation name= "@export_global_file" qualifiers= "vararg" >
<return type= "void" />
2022-07-11 22:02:55 +02:00
<argument index= "0" name= "filter" type= "String" default= """" />
2022-07-04 17:56:34 +02:00
<description >
</description>
</annotation>
2022-07-06 16:37:40 +02:00
<annotation name= "@export_group" >
<return type= "void" />
<argument index= "0" name= "name" type= "String" />
2022-07-11 22:02:55 +02:00
<argument index= "1" name= "prefix" type= "String" default= """" />
2022-07-06 16:37:40 +02:00
<description >
</description>
</annotation>
2022-07-04 17:56:34 +02:00
<annotation name= "@export_multiline" >
<return type= "void" />
<description >
</description>
</annotation>
<annotation name= "@export_node_path" qualifiers= "vararg" >
<return type= "void" />
2022-07-11 22:02:55 +02:00
<argument index= "0" name= "type" type= "String" default= """" />
2022-07-04 17:56:34 +02:00
<description >
</description>
</annotation>
<annotation name= "@export_placeholder" >
<return type= "void" />
<description >
</description>
</annotation>
2022-07-11 22:02:55 +02:00
<annotation name= "@export_range" qualifiers= "vararg" >
2022-07-04 17:56:34 +02:00
<return type= "void" />
<argument index= "0" name= "min" type= "float" />
<argument index= "1" name= "max" type= "float" />
2022-07-11 22:02:55 +02:00
<argument index= "2" name= "step" type= "float" default= "1.0" />
<argument index= "3" name= "extra_hints" type= "String" default= """" />
2022-07-04 17:56:34 +02:00
<description >
</description>
2022-07-06 16:37:40 +02:00
</annotation>
<annotation name= "@export_subgroup" >
<return type= "void" />
<argument index= "0" name= "name" type= "String" />
2022-07-11 22:02:55 +02:00
<argument index= "1" name= "prefix" type= "String" default= """" />
2022-07-06 16:37:40 +02:00
<description >
</description>
2022-07-04 17:56:34 +02:00
</annotation>
<annotation name= "@icon" >
<return type= "void" />
<argument index= "0" name= "icon_path" type= "String" />
<description >
</description>
</annotation>
<annotation name= "@onready" >
<return type= "void" />
<description >
</description>
</annotation>
<annotation name= "@rpc" qualifiers= "vararg" >
<return type= "void" />
2022-07-11 22:02:55 +02:00
<argument index= "0" name= "mode" type= "String" default= """" />
<argument index= "1" name= "sync" type= "String" default= """" />
<argument index= "2" name= "transfer_mode" type= "String" default= """" />
<argument index= "3" name= "transfer_channel" type= "int" default= "0" />
2022-07-04 17:56:34 +02:00
<description >
</description>
</annotation>
<annotation name= "@tool" >
<return type= "void" />
<description >
</description>
</annotation>
<annotation name= "@warning_ignore" qualifiers= "vararg" >
<return type= "void" />
<argument index= "0" name= "warning" type= "String" />
<description >
</description>
</annotation>
</annotations>
2017-09-12 22:42:36 +02:00
</class>