Attention: Here be dragons (unstable version)
        This is the latest
        (unstable) version of this documentation, which may document features
        not available in or compatible with released stable versions of Redot.
      
Checking the stable version of the documentation...
ClassDB
Inherits: Object
A class information repository.
Description
Provides access to metadata stored for every available class.
Methods
Enumerations
enum APIType: 🔗
APIType API_CORE = 0
Native Core class type.
APIType API_EDITOR = 1
Native Editor class type.
APIType API_EXTENSION = 2
GDExtension class type.
APIType API_EDITOR_EXTENSION = 3
GDExtension Editor class type.
APIType API_NONE = 4
Unknown class type.
Method Descriptions
bool can_instantiate(class: StringName) const 🔗
Returns true if objects can be instantiated from the specified class, otherwise returns false.
Variant class_call_static(class: StringName, method: StringName, ...) vararg 🔗
Calls a static method on a class.
bool class_exists(class: StringName) const 🔗
Returns whether the specified class is available or not.
APIType class_get_api_type(class: StringName) const 🔗
Returns the API type of class. See APIType.
PackedStringArray class_get_enum_constants(class: StringName, enum: StringName, no_inheritance: bool = false) const 🔗
Returns an array with all the keys in enum of class or its ancestry.
PackedStringArray class_get_enum_list(class: StringName, no_inheritance: bool = false) const 🔗
Returns an array with all the enums of class or its ancestry.
int class_get_integer_constant(class: StringName, name: StringName) const 🔗
Returns the value of the integer constant name of class or its ancestry. Always returns 0 when the constant could not be found.
StringName class_get_integer_constant_enum(class: StringName, name: StringName, no_inheritance: bool = false) const 🔗
Returns which enum the integer constant name of class or its ancestry belongs to.
PackedStringArray class_get_integer_constant_list(class: StringName, no_inheritance: bool = false) const 🔗
Returns an array with the names all the integer constants of class or its ancestry.
int class_get_method_argument_count(class: StringName, method: StringName, no_inheritance: bool = false) const 🔗
Returns the number of arguments of the method method of class or its ancestry if no_inheritance is false.
Array[Dictionary] class_get_method_list(class: StringName, no_inheritance: bool = false) const 🔗
Returns an array with all the methods of class or its ancestry if no_inheritance is false. Every element of the array is a Dictionary with the following keys: args, default_args, flags, id, name, return: (class_name, hint, hint_string, name, type, usage).
Note: In exported release builds the debug info is not available, so the returned dictionaries will contain only method names.
Variant class_get_property(object: Object, property: StringName) const 🔗
Returns the value of property of object or its ancestry.
Variant class_get_property_default_value(class: StringName, property: StringName) const 🔗
Returns the default value of property of class or its ancestor classes.
StringName class_get_property_getter(class: StringName, property: StringName) 🔗
Returns the getter method name of property of class.
Array[Dictionary] class_get_property_list(class: StringName, no_inheritance: bool = false) const 🔗
Returns an array with all the properties of class or its ancestry if no_inheritance is false.
StringName class_get_property_setter(class: StringName, property: StringName) 🔗
Returns the setter method name of property of class.
Dictionary class_get_signal(class: StringName, signal: StringName) const 🔗
Returns the signal data of class or its ancestry. The returned value is a Dictionary with the following keys: args, default_args, flags, id, name, return: (class_name, hint, hint_string, name, type, usage).
Array[Dictionary] class_get_signal_list(class: StringName, no_inheritance: bool = false) const 🔗
Returns an array with all the signals of class or its ancestry if no_inheritance is false. Every element of the array is a Dictionary as described in class_get_signal.
bool class_has_enum(class: StringName, name: StringName, no_inheritance: bool = false) const 🔗
Returns whether class or its ancestry has an enum called name or not.
bool class_has_integer_constant(class: StringName, name: StringName) const 🔗
Returns whether class or its ancestry has an integer constant called name or not.
bool class_has_method(class: StringName, method: StringName, no_inheritance: bool = false) const 🔗
Returns whether class (or its ancestry if no_inheritance is false) has a method called method or not.
bool class_has_signal(class: StringName, signal: StringName) const 🔗
Returns whether class or its ancestry has a signal called signal or not.
Error class_set_property(object: Object, property: StringName, value: Variant) const 🔗
Sets property value of object to value.
PackedStringArray get_class_list() const 🔗
Returns the names of all the classes available.
PackedStringArray get_inheriters_from_class(class: StringName) const 🔗
Returns the names of all the classes that directly or indirectly inherit from class.
StringName get_parent_class(class: StringName) const 🔗
Returns the parent class of class.
Variant instantiate(class: StringName) const 🔗
Creates an instance of class.
bool is_class_enabled(class: StringName) const 🔗
Returns whether this class is enabled or not.
bool is_class_enum_bitfield(class: StringName, enum: StringName, no_inheritance: bool = false) const 🔗
Returns whether class (or its ancestor classes if no_inheritance is false) has an enum called enum that is a bitfield.
bool is_parent_class(class: StringName, inherits: StringName) const 🔗
Returns whether inherits is an ancestor of class or not.