2017-09-12 22:42:36 +02:00
<?xml version="1.0" encoding="UTF-8" ?>
2023-07-06 10:08:05 +02:00
<class name= "ClassDB" inherits= "Object" xmlns:xsi= "http://www.w3.org/2001/XMLSchema-instance" xsi:noNamespaceSchemaLocation= "../class.xsd" >
2017-09-12 22:42:36 +02:00
<brief_description >
2023-04-28 01:35:33 +02:00
A class information repository.
2017-09-12 22:42:36 +02:00
</brief_description>
<description >
2017-09-13 00:18:26 +02:00
Provides access to metadata stored for every available class.
2017-09-12 22:42:36 +02:00
</description>
<tutorials >
</tutorials>
<methods >
2021-06-18 00:03:09 +02:00
<method name= "can_instantiate" qualifiers= "const" >
2021-07-30 15:28:05 +02:00
<return type= "bool" />
2022-08-06 20:11:48 +02:00
<param index= "0" name= "class" type= "StringName" />
2017-09-12 22:42:36 +02:00
<description >
2022-10-20 04:09:17 +02:00
Returns [code]true[/code] if objects can be instantiated from the specified [param class], otherwise returns [code]false[/code].
2017-09-12 22:42:36 +02:00
</description>
</method>
2024-08-23 01:56:29 +02:00
<method name= "class_call_static_method" qualifiers= "vararg" >
<return type= "Variant" />
<param index= "0" name= "class" type= "StringName" />
<param index= "1" name= "method" type= "StringName" />
<description >
Calls a static method on a class.
</description>
</method>
2017-09-12 22:42:36 +02:00
<method name= "class_exists" qualifiers= "const" >
2021-07-30 15:28:05 +02:00
<return type= "bool" />
2022-08-06 20:11:48 +02:00
<param index= "0" name= "class" type= "StringName" />
2017-09-12 22:42:36 +02:00
<description >
2022-08-12 19:13:27 +02:00
Returns whether the specified [param class] is available or not.
2017-09-12 22:42:36 +02:00
</description>
</method>
2024-04-15 17:50:15 +02:00
<method name= "class_get_api_type" qualifiers= "const" >
<return type= "int" enum= "ClassDB.APIType" />
<param index= "0" name= "class" type= "StringName" />
<description >
Returns the API type of [param class]. See [enum APIType].
</description>
</method>
2021-09-11 14:31:11 +02:00
<method name= "class_get_enum_constants" qualifiers= "const" >
<return type= "PackedStringArray" />
2022-08-06 20:11:48 +02:00
<param index= "0" name= "class" type= "StringName" />
<param index= "1" name= "enum" type= "StringName" />
<param index= "2" name= "no_inheritance" type= "bool" default= "false" />
2021-09-11 14:31:11 +02:00
<description >
2022-08-12 19:13:27 +02:00
Returns an array with all the keys in [param enum] of [param class] or its ancestry.
2021-09-11 14:31:11 +02:00
</description>
</method>
<method name= "class_get_enum_list" qualifiers= "const" >
<return type= "PackedStringArray" />
2022-08-06 20:11:48 +02:00
<param index= "0" name= "class" type= "StringName" />
<param index= "1" name= "no_inheritance" type= "bool" default= "false" />
2021-09-11 14:31:11 +02:00
<description >
2022-08-12 19:13:27 +02:00
Returns an array with all the enums of [param class] or its ancestry.
2021-09-11 14:31:11 +02:00
</description>
</method>
2017-09-12 22:42:36 +02:00
<method name= "class_get_integer_constant" qualifiers= "const" >
2021-07-30 15:28:05 +02:00
<return type= "int" />
2022-08-06 20:11:48 +02:00
<param index= "0" name= "class" type= "StringName" />
<param index= "1" name= "name" type= "StringName" />
2017-09-12 22:42:36 +02:00
<description >
2022-08-12 19:13:27 +02:00
Returns the value of the integer constant [param name] of [param class] or its ancestry. Always returns 0 when the constant could not be found.
2017-09-12 22:42:36 +02:00
</description>
</method>
2021-09-11 14:31:11 +02:00
<method name= "class_get_integer_constant_enum" qualifiers= "const" >
<return type= "StringName" />
2022-08-06 20:11:48 +02:00
<param index= "0" name= "class" type= "StringName" />
<param index= "1" name= "name" type= "StringName" />
<param index= "2" name= "no_inheritance" type= "bool" default= "false" />
2021-09-11 14:31:11 +02:00
<description >
2022-08-12 19:13:27 +02:00
Returns which enum the integer constant [param name] of [param class] or its ancestry belongs to.
2021-09-11 14:31:11 +02:00
</description>
</method>
2017-09-12 22:42:36 +02:00
<method name= "class_get_integer_constant_list" qualifiers= "const" >
2021-07-30 15:28:05 +02:00
<return type= "PackedStringArray" />
2022-08-06 20:11:48 +02:00
<param index= "0" name= "class" type= "StringName" />
<param index= "1" name= "no_inheritance" type= "bool" default= "false" />
2017-09-12 22:42:36 +02:00
<description >
2022-08-12 19:13:27 +02:00
Returns an array with the names all the integer constants of [param class] or its ancestry.
2017-09-12 22:42:36 +02:00
</description>
</method>
2024-01-28 15:16:09 +01:00
<method name= "class_get_method_argument_count" qualifiers= "const" >
<return type= "int" />
<param index= "0" name= "class" type= "StringName" />
<param index= "1" name= "method" type= "StringName" />
<param index= "2" name= "no_inheritance" type= "bool" default= "false" />
<description >
Returns the number of arguments of the method [param method] of [param class] or its ancestry if [param no_inheritance] is [code]false[/code].
</description>
</method>
2017-09-12 22:42:36 +02:00
<method name= "class_get_method_list" qualifiers= "const" >
2022-08-05 03:41:48 +02:00
<return type= "Dictionary[]" />
2022-08-06 20:11:48 +02:00
<param index= "0" name= "class" type= "StringName" />
<param index= "1" name= "no_inheritance" type= "bool" default= "false" />
2017-09-12 22:42:36 +02:00
<description >
2022-08-12 19:13:27 +02:00
Returns an array with all the methods of [param class] or its ancestry if [param no_inheritance] is [code]false[/code]. Every element of the array is a [Dictionary] with the following keys: [code]args[/code], [code]default_args[/code], [code]flags[/code], [code]id[/code], [code]name[/code], [code]return: (class_name, hint, hint_string, name, type, usage)[/code].
2021-10-05 14:24:34 +02:00
[b]Note:[/b] In exported release builds the debug info is not available, so the returned dictionaries will contain only method names.
2017-09-12 22:42:36 +02:00
</description>
</method>
<method name= "class_get_property" qualifiers= "const" >
2021-07-30 15:28:05 +02:00
<return type= "Variant" />
2022-08-06 20:11:48 +02:00
<param index= "0" name= "object" type= "Object" />
<param index= "1" name= "property" type= "StringName" />
2017-09-12 22:42:36 +02:00
<description >
2022-08-12 19:13:27 +02:00
Returns the value of [param property] of [param object] or its ancestry.
2017-09-12 22:42:36 +02:00
</description>
</method>
2024-04-19 19:51:28 +02:00
<method name= "class_get_property_default_value" qualifiers= "const" >
<return type= "Variant" />
<param index= "0" name= "class" type= "StringName" />
<param index= "1" name= "property" type= "StringName" />
<description >
Returns the default value of [param property] of [param class] or its ancestor classes.
</description>
</method>
2024-07-27 05:53:13 +02:00
<method name= "class_get_property_getter" >
<return type= "StringName" />
<param index= "0" name= "class" type= "StringName" />
<param index= "1" name= "property" type= "StringName" />
<description >
Returns the getter method name of [param property] of [param class].
</description>
</method>
2017-09-12 22:42:36 +02:00
<method name= "class_get_property_list" qualifiers= "const" >
2022-08-05 03:41:48 +02:00
<return type= "Dictionary[]" />
2022-08-06 20:11:48 +02:00
<param index= "0" name= "class" type= "StringName" />
<param index= "1" name= "no_inheritance" type= "bool" default= "false" />
2017-09-12 22:42:36 +02:00
<description >
2022-08-12 19:13:27 +02:00
Returns an array with all the properties of [param class] or its ancestry if [param no_inheritance] is [code]false[/code].
2017-09-12 22:42:36 +02:00
</description>
</method>
2024-07-27 05:53:13 +02:00
<method name= "class_get_property_setter" >
<return type= "StringName" />
<param index= "0" name= "class" type= "StringName" />
<param index= "1" name= "property" type= "StringName" />
<description >
Returns the setter method name of [param property] of [param class].
</description>
</method>
2017-09-12 22:42:36 +02:00
<method name= "class_get_signal" qualifiers= "const" >
2021-07-30 15:28:05 +02:00
<return type= "Dictionary" />
2022-08-06 20:11:48 +02:00
<param index= "0" name= "class" type= "StringName" />
<param index= "1" name= "signal" type= "StringName" />
2017-09-12 22:42:36 +02:00
<description >
2022-08-12 19:13:27 +02:00
Returns the [param signal] data of [param class] or its ancestry. The returned value is a [Dictionary] with the following keys: [code]args[/code], [code]default_args[/code], [code]flags[/code], [code]id[/code], [code]name[/code], [code]return: (class_name, hint, hint_string, name, type, usage)[/code].
2017-09-12 22:42:36 +02:00
</description>
</method>
<method name= "class_get_signal_list" qualifiers= "const" >
2022-08-05 03:41:48 +02:00
<return type= "Dictionary[]" />
2022-08-06 20:11:48 +02:00
<param index= "0" name= "class" type= "StringName" />
<param index= "1" name= "no_inheritance" type= "bool" default= "false" />
2017-09-12 22:42:36 +02:00
<description >
2022-08-12 19:13:27 +02:00
Returns an array with all the signals of [param class] or its ancestry if [param no_inheritance] is [code]false[/code]. Every element of the array is a [Dictionary] as described in [method class_get_signal].
2017-09-12 22:42:36 +02:00
</description>
</method>
2021-09-11 14:31:11 +02:00
<method name= "class_has_enum" qualifiers= "const" >
<return type= "bool" />
2022-08-06 20:11:48 +02:00
<param index= "0" name= "class" type= "StringName" />
<param index= "1" name= "name" type= "StringName" />
<param index= "2" name= "no_inheritance" type= "bool" default= "false" />
2021-09-11 14:31:11 +02:00
<description >
2022-08-12 19:13:27 +02:00
Returns whether [param class] or its ancestry has an enum called [param name] or not.
2021-09-11 14:31:11 +02:00
</description>
</method>
2017-09-12 22:42:36 +02:00
<method name= "class_has_integer_constant" qualifiers= "const" >
2021-07-30 15:28:05 +02:00
<return type= "bool" />
2022-08-06 20:11:48 +02:00
<param index= "0" name= "class" type= "StringName" />
<param index= "1" name= "name" type= "StringName" />
2017-09-12 22:42:36 +02:00
<description >
2022-08-12 19:13:27 +02:00
Returns whether [param class] or its ancestry has an integer constant called [param name] or not.
2017-09-12 22:42:36 +02:00
</description>
</method>
<method name= "class_has_method" qualifiers= "const" >
2021-07-30 15:28:05 +02:00
<return type= "bool" />
2022-08-06 20:11:48 +02:00
<param index= "0" name= "class" type= "StringName" />
<param index= "1" name= "method" type= "StringName" />
<param index= "2" name= "no_inheritance" type= "bool" default= "false" />
2017-09-12 22:42:36 +02:00
<description >
2022-08-12 19:13:27 +02:00
Returns whether [param class] (or its ancestry if [param no_inheritance] is [code]false[/code]) has a method called [param method] or not.
2017-09-12 22:42:36 +02:00
</description>
</method>
<method name= "class_has_signal" qualifiers= "const" >
2021-07-30 15:28:05 +02:00
<return type= "bool" />
2022-08-06 20:11:48 +02:00
<param index= "0" name= "class" type= "StringName" />
<param index= "1" name= "signal" type= "StringName" />
2017-09-12 22:42:36 +02:00
<description >
2022-08-12 19:13:27 +02:00
Returns whether [param class] or its ancestry has a signal called [param signal] or not.
2017-09-12 22:42:36 +02:00
</description>
</method>
<method name= "class_set_property" qualifiers= "const" >
2021-07-30 15:28:05 +02:00
<return type= "int" enum= "Error" />
2022-08-06 20:11:48 +02:00
<param index= "0" name= "object" type= "Object" />
<param index= "1" name= "property" type= "StringName" />
<param index= "2" name= "value" type= "Variant" />
2017-09-12 22:42:36 +02:00
<description >
2022-08-12 19:13:27 +02:00
Sets [param property] value of [param object] to [param value].
2017-09-12 22:42:36 +02:00
</description>
</method>
<method name= "get_class_list" qualifiers= "const" >
2021-07-30 15:28:05 +02:00
<return type= "PackedStringArray" />
2017-09-12 22:42:36 +02:00
<description >
2017-09-13 00:18:26 +02:00
Returns the names of all the classes available.
2017-09-12 22:42:36 +02:00
</description>
</method>
<method name= "get_inheriters_from_class" qualifiers= "const" >
2021-07-30 15:28:05 +02:00
<return type= "PackedStringArray" />
2022-08-06 20:11:48 +02:00
<param index= "0" name= "class" type= "StringName" />
2017-09-12 22:42:36 +02:00
<description >
2022-08-12 19:13:27 +02:00
Returns the names of all the classes that directly or indirectly inherit from [param class].
2017-09-12 22:42:36 +02:00
</description>
</method>
<method name= "get_parent_class" qualifiers= "const" >
2021-07-30 15:28:05 +02:00
<return type= "StringName" />
2022-08-06 20:11:48 +02:00
<param index= "0" name= "class" type= "StringName" />
2017-09-12 22:42:36 +02:00
<description >
2022-08-12 19:13:27 +02:00
Returns the parent class of [param class].
2017-09-12 22:42:36 +02:00
</description>
</method>
2021-06-18 00:03:09 +02:00
<method name= "instantiate" qualifiers= "const" >
2021-07-30 15:28:05 +02:00
<return type= "Variant" />
2022-08-06 20:11:48 +02:00
<param index= "0" name= "class" type= "StringName" />
2017-09-12 22:42:36 +02:00
<description >
2022-08-12 19:13:27 +02:00
Creates an instance of [param class].
2017-09-12 22:42:36 +02:00
</description>
</method>
<method name= "is_class_enabled" qualifiers= "const" >
2021-07-30 15:28:05 +02:00
<return type= "bool" />
2022-08-06 20:11:48 +02:00
<param index= "0" name= "class" type= "StringName" />
2017-09-12 22:42:36 +02:00
<description >
2022-08-12 19:13:27 +02:00
Returns whether this [param class] is enabled or not.
2017-09-12 22:42:36 +02:00
</description>
</method>
2024-04-08 01:21:19 +02:00
<method name= "is_class_enum_bitfield" qualifiers= "const" >
<return type= "bool" />
<param index= "0" name= "class" type= "StringName" />
<param index= "1" name= "enum" type= "StringName" />
<param index= "2" name= "no_inheritance" type= "bool" default= "false" />
<description >
Returns whether [param class] (or its ancestor classes if [param no_inheritance] is [code]false[/code]) has an enum called [param enum] that is a bitfield.
</description>
</method>
2017-09-12 22:42:36 +02:00
<method name= "is_parent_class" qualifiers= "const" >
2021-07-30 15:28:05 +02:00
<return type= "bool" />
2022-08-06 20:11:48 +02:00
<param index= "0" name= "class" type= "StringName" />
<param index= "1" name= "inherits" type= "StringName" />
2017-09-12 22:42:36 +02:00
<description >
2022-08-12 19:13:27 +02:00
Returns whether [param inherits] is an ancestor of [param class] or not.
2017-09-12 22:42:36 +02:00
</description>
</method>
</methods>
2024-04-15 17:50:15 +02:00
<constants >
<constant name= "API_CORE" value= "0" enum= "APIType" >
Native Core class type.
</constant>
<constant name= "API_EDITOR" value= "1" enum= "APIType" >
Native Editor class type.
</constant>
<constant name= "API_EXTENSION" value= "2" enum= "APIType" >
GDExtension class type.
</constant>
<constant name= "API_EDITOR_EXTENSION" value= "3" enum= "APIType" >
GDExtension Editor class type.
</constant>
<constant name= "API_NONE" value= "4" enum= "APIType" >
Unknown class type.
</constant>
</constants>
2017-09-12 22:42:36 +02:00
</class>