Document FuncRef, GDFunctionState, InstancePlaceholder, RID, World2D

This commit is contained in:
eska 2016-07-30 20:41:38 +02:00
parent 73f83fadc8
commit b80c42ef4e
3 changed files with 28 additions and 4 deletions

View File

@ -65,7 +65,7 @@ void FuncRef::_bind_methods() {
mi.arguments.push_back( PropertyInfo( Variant::NIL, "arg"+itos(i))); mi.arguments.push_back( PropertyInfo( Variant::NIL, "arg"+itos(i)));
defargs.push_back(Variant()); defargs.push_back(Variant());
} }
ObjectTypeDB::bind_native_method(METHOD_FLAGS_DEFAULT,"call_func",&FuncRef::call_func,mi,defargs); ObjectTypeDB::bind_native_method(METHOD_FLAGS_DEFAULT,"call_func:Variant",&FuncRef::call_func,mi,defargs);
} }

View File

@ -660,7 +660,7 @@
<argument index="1" name="signal" type="String"> <argument index="1" name="signal" type="String">
</argument> </argument>
<description> <description>
Stop the function execution and return the current state. Call resume on the state to resume execution. This makes the state invalid. Stop the function execution and return the current state. Call [method GDFunctionState.resume] on the state to resume execution. This invalidates the state.
Returns anything that was passed to the resume function call. If passed an object and a signal, the execution is resumed when the object's signal is emmited. Returns anything that was passed to the resume function call. If passed an object and a signal, the execution is resumed when the object's signal is emmited.
</description> </description>
</method> </method>
@ -13042,8 +13042,11 @@
</class> </class>
<class name="FuncRef" inherits="Reference" category="Core"> <class name="FuncRef" inherits="Reference" category="Core">
<brief_description> <brief_description>
Reference to a function in an object.
</brief_description> </brief_description>
<description> <description>
In GDScript, functions are not [i]first-class objects[/i]. This means it is impossible to store them directly as variables, return them from another function, or pass them as arguments.
However, by creating a [FuncRef] using the [method @GDScript.funcref] function, a reference to a function in a given object can be created, passed around and called.
</description> </description>
<methods> <methods>
<method name="call_func"> <method name="call_func">
@ -13068,18 +13071,21 @@
<argument index="9" name="arg9" type="Variant" default="NULL"> <argument index="9" name="arg9" type="Variant" default="NULL">
</argument> </argument>
<description> <description>
Call the referenced function with the given arguments. The argument count must correspond to the required number of arguments in the function. Returns the return value of the function call.
</description> </description>
</method> </method>
<method name="set_function"> <method name="set_function">
<argument index="0" name="name" type="String"> <argument index="0" name="name" type="String">
</argument> </argument>
<description> <description>
Set the name of the function to call on the object, without parentheses or any parameters.
</description> </description>
</method> </method>
<method name="set_instance"> <method name="set_instance">
<argument index="0" name="instance" type="Object"> <argument index="0" name="instance" type="Object">
</argument> </argument>
<description> <description>
Set the object on which to call the referenced function. This object must be of a type actually inheriting from [Object], not a built-in type such as [int], [Vector2] or [Dictionary].
</description> </description>
</method> </method>
</methods> </methods>
@ -13088,15 +13094,17 @@
</class> </class>
<class name="GDFunctionState" inherits="Reference" category="Core"> <class name="GDFunctionState" inherits="Reference" category="Core">
<brief_description> <brief_description>
State of a function call after yielding.
</brief_description> </brief_description>
<description> <description>
Calling [method @GDScript.yield] within a function will cause that function to yield and return its current state as an object of this type. The yielded function call can then be resumed later by calling [method resume] on this state object.
</description> </description>
<methods> <methods>
<method name="is_valid" qualifiers="const"> <method name="is_valid" qualifiers="const">
<return type="bool"> <return type="bool">
</return> </return>
<description> <description>
Should put children to the top left corner instead of center of the container. Check whether the function call may be resumed. This is not the case if the function state was already resumed.
</description> </description>
</method> </method>
<method name="resume"> <method name="resume">
@ -13105,6 +13113,9 @@
<argument index="0" name="arg" type="Variant" default="NULL"> <argument index="0" name="arg" type="Variant" default="NULL">
</argument> </argument>
<description> <description>
Resume execution of the yielded function call.
If handed an argument, return the argument from the [method @GDScript.yield] call in the yielded function call. You can pass e.g. an [Array] to hand multiple arguments.
This function returns what the resumed function call returns, possibly another function state if yielded again.
</description> </description>
</method> </method>
</methods> </methods>
@ -17235,20 +17246,25 @@
</class> </class>
<class name="InstancePlaceholder" inherits="Node" category="Core"> <class name="InstancePlaceholder" inherits="Node" category="Core">
<brief_description> <brief_description>
Placeholder for the root [Node] of a [PackedScene].
</brief_description> </brief_description>
<description> <description>
Turning on the option [b]Load As Placeholder[/b] for an instanced scene in the editor causes it to be replaced by an InstacePlaceholder when running the game. This makes it possible to delay actually loading the scene until calling [method replace_by_instance]. This is useful to avoid loading large scenes all at once by loading parts of it selectively.
The InstancePlaceholder does not have a transform. This causes any child nodes to be positioned relatively to the Viewport from point (0,0), rather than their parent as displayed in the editor. Replacing the placeholder with a scene with a transform will transform children relatively to their parent again.
</description> </description>
<methods> <methods>
<method name="get_instance_path" qualifiers="const"> <method name="get_instance_path" qualifiers="const">
<return type="String"> <return type="String">
</return> </return>
<description> <description>
Retrieve the path to the [PackedScene] resource file that is loaded by default when calling [method replace_by_instance].
</description> </description>
</method> </method>
<method name="replace_by_instance"> <method name="replace_by_instance">
<argument index="0" name="custom_scene" type="PackedScene" default="NULL"> <argument index="0" name="custom_scene" type="PackedScene" default="NULL">
</argument> </argument>
<description> <description>
Replace this placeholder by the scene handed as an argument, or the original scene if no argument is given. As for all resources, the scene is loaded only if it's not loaded already. By manually loading the scene beforehand, delays caused by this function can be avoided.
</description> </description>
</method> </method>
</methods> </methods>
@ -30280,8 +30296,10 @@
</class> </class>
<class name="RID" category="Built-In Types"> <class name="RID" category="Built-In Types">
<brief_description> <brief_description>
Handle for a [Resource]'s unique ID.
</brief_description> </brief_description>
<description> <description>
The RID type is used to access the unique integer ID of a resource. They are opaque, so they do not grant access to the associated resource by themselves. They are used by and with the low-level Server classes such as [VisualServer].
</description> </description>
<methods> <methods>
<method name="RID"> <method name="RID">
@ -30290,12 +30308,14 @@
<argument index="0" name="from" type="Object"> <argument index="0" name="from" type="Object">
</argument> </argument>
<description> <description>
Create a new RID instance with the ID of a given resource. When not handed a valid resource, silently stores the unused ID 0.
</description> </description>
</method> </method>
<method name="get_id"> <method name="get_id">
<return type="int"> <return type="int">
</return> </return>
<description> <description>
Retrieve the ID of the referenced resource.
</description> </description>
</method> </method>
</methods> </methods>
@ -46584,24 +46604,28 @@
<return type="RID"> <return type="RID">
</return> </return>
<description> <description>
Retrieve the [RID] of this world's canvas resource. Used by the [VisualServer] for 2D drawing.
</description> </description>
</method> </method>
<method name="get_direct_space_state"> <method name="get_direct_space_state">
<return type="Physics2DDirectSpaceState"> <return type="Physics2DDirectSpaceState">
</return> </return>
<description> <description>
Retrieve the state of this world's physics space. This allows arbitrary querying for collision.
</description> </description>
</method> </method>
<method name="get_sound_space"> <method name="get_sound_space">
<return type="RID"> <return type="RID">
</return> </return>
<description> <description>
Retrieve the [RID] of this world's sound space resource. Used by the [SpatialSound2DServer] for 2D spatial audio.
</description> </description>
</method> </method>
<method name="get_space"> <method name="get_space">
<return type="RID"> <return type="RID">
</return> </return>
<description> <description>
Retrieve the [RID] of this world's physics space resource. Used by the [Physics2DServer] for 2D physics, treating it as both a space and an area.
</description> </description>
</method> </method>
</methods> </methods>

View File

@ -297,7 +297,7 @@ void GDScriptLanguage::get_public_functions(List<MethodInfo> *p_functions) const
} }
{ {
MethodInfo mi; MethodInfo mi;
mi.name="yield"; mi.name="yield:GDFunctionState";
mi.arguments.push_back(PropertyInfo(Variant::OBJECT,"object")); mi.arguments.push_back(PropertyInfo(Variant::OBJECT,"object"));
mi.arguments.push_back(PropertyInfo(Variant::STRING,"signal")); mi.arguments.push_back(PropertyInfo(Variant::STRING,"signal"));
mi.default_arguments.push_back(Variant::NIL); mi.default_arguments.push_back(Variant::NIL);