now using a more compact example project
This commit is contained in:
		
										
											Binary file not shown.
										
									
								
							| @@ -1,80 +0,0 @@ | ||||
| extends Node | ||||
|  | ||||
| func _ready(): | ||||
| 	# Bind signals | ||||
| 	prints("Signal bind") | ||||
| 	$Button.button_up.connect($Example.emit_custom_signal.bind("Button", 42)) | ||||
|  | ||||
| 	prints("") | ||||
|  | ||||
| 	# To string. | ||||
| 	prints("To string") | ||||
| 	prints("  Example --> ", $Example.to_string()) | ||||
| 	prints("  ExampleMin --> ", $Example/ExampleMin.to_string()) | ||||
|  | ||||
| 	# Call static methods. | ||||
| 	prints("Static method calls") | ||||
| 	prints("  static (109)", Example.test_static(9, 100)); | ||||
| 	Example.test_static2(); | ||||
|  | ||||
| 	# Property list. | ||||
| 	prints("Property list") | ||||
| 	$Example.property_from_list = Vector3(100, 200, 300) | ||||
| 	prints("  property value ", $Example.property_from_list) | ||||
|  | ||||
| 	# Call methods. | ||||
| 	prints("Instance method calls") | ||||
| 	$Example.simple_func() | ||||
| 	($Example as Example).simple_const_func() # Force use of ptrcall | ||||
| 	prints("  returned", $Example.return_something("some string")) | ||||
| 	prints("  returned const", $Example.return_something_const()) | ||||
| 	var null_ref = $Example.return_empty_ref() | ||||
| 	prints("  returned empty ref", null_ref) | ||||
| 	var ret_ref = $Example.return_extended_ref() | ||||
| 	prints("  returned ref", ret_ref.get_instance_id(), ", id:", ret_ref.get_id()) | ||||
| 	prints("  returned ", $Example.get_v4()) | ||||
| 	prints("  test node argument", $Example.test_node_argument($Example)) | ||||
|  | ||||
| 	prints("VarArg method calls") | ||||
| 	var ref = ExampleRef.new() | ||||
| 	prints("  sending ref: ", ref.get_instance_id(), "returned ref: ", $Example.extended_ref_checks(ref).get_instance_id()) | ||||
| 	prints("  vararg args", $Example.varargs_func("some", "arguments", "to", "test")) | ||||
| 	prints("  vararg_nv ret", $Example.varargs_func_nv("some", "arguments", "to", "test")) | ||||
| 	$Example.varargs_func_void("some", "arguments", "to", "test") | ||||
|  | ||||
| 	prints("Method calls with default values") | ||||
| 	prints("  defval (300)", $Example.def_args()) | ||||
| 	prints("  defval (250)", $Example.def_args(50)) | ||||
| 	prints("  defval (150)", $Example.def_args(50, 100)) | ||||
|  | ||||
| 	prints("Array and Dictionary") | ||||
| 	prints("  test array", $Example.test_array()) | ||||
| 	prints("  test tarray", $Example.test_tarray()) | ||||
| 	prints("  test dictionary", $Example.test_dictionary()) | ||||
| 	var array: Array[int] = [1, 2, 3] | ||||
| 	$Example.test_tarray_arg(array) | ||||
|  | ||||
| 	prints("String += operator") | ||||
| 	prints("  test string +=", $Example.test_string_ops()) | ||||
|  | ||||
| 	prints("PackedArray iterators") | ||||
| 	prints("  test packed array iterators", $Example.test_vector_ops()) | ||||
|  | ||||
| 	prints("Properties") | ||||
| 	prints("  custom position is", $Example.group_subgroup_custom_position) | ||||
| 	$Example.group_subgroup_custom_position = Vector2(50, 50) | ||||
| 	prints("  custom position now is", $Example.group_subgroup_custom_position) | ||||
|  | ||||
| 	prints("Constants") | ||||
| 	prints("  FIRST", $Example.FIRST) | ||||
| 	prints("  ANSWER_TO_EVERYTHING", $Example.ANSWER_TO_EVERYTHING) | ||||
| 	prints("  CONSTANT_WITHOUT_ENUM", $Example.CONSTANT_WITHOUT_ENUM) | ||||
|  | ||||
| 	prints("BitFields") | ||||
| 	prints("  FLAG_ONE", Example.FLAG_ONE) | ||||
| 	prints("  FLAG_TWO", Example.FLAG_TWO) | ||||
| 	prints("  returned BitField", $Example.test_bitfield(0)) | ||||
| 	prints("  returned BitField", $Example.test_bitfield(Example.FLAG_ONE | Example.FLAG_TWO)) | ||||
|  | ||||
| func _on_Example_custom_signal(signal_name, value): | ||||
| 	prints("Example emitted:", signal_name, value) | ||||
| @@ -1,25 +1,14 @@ | ||||
| [gd_scene load_steps=2 format=3 uid="uid://dmx2xuigcpvt4"] | ||||
|  | ||||
| [ext_resource type="Script" path="res://main.gd" id="1_c326s"] | ||||
| [ext_resource type="Texture2D" uid="uid://cswr8vy4lt7dt" path="res://icon.png" id="1_qdvaq"] | ||||
|  | ||||
| [node name="Node" type="Node"] | ||||
| script = ExtResource("1_c326s") | ||||
|  | ||||
| [node name="Example" type="Example" parent="."] | ||||
|  | ||||
| [node name="ExampleMin" type="ExampleMin" parent="Example"] | ||||
| layout_mode = 0 | ||||
|  | ||||
| [node name="Label" type="Label" parent="Example"] | ||||
| layout_mode = 0 | ||||
| offset_left = 194.0 | ||||
| offset_top = -2.0 | ||||
| offset_right = 234.0 | ||||
| offset_bottom = 21.0 | ||||
|  | ||||
| [node name="Button" type="Button" parent="."] | ||||
| offset_right = 79.0 | ||||
| offset_bottom = 29.0 | ||||
| text = "Click me!" | ||||
|  | ||||
| [connection signal="custom_signal" from="Example" to="." method="_on_Example_custom_signal"] | ||||
| [node name="GDExample" type="GDExample" parent="."] | ||||
| position = Vector2(0.0676828, 0.462702) | ||||
| texture = ExtResource("1_qdvaq") | ||||
|   | ||||
							
								
								
									
										338
									
								
								src/example.cpp
									
									
									
									
									
								
							
							
						
						
									
										338
									
								
								src/example.cpp
									
									
									
									
									
								
							| @@ -1,338 +0,0 @@ | ||||
| /* godot-cpp integration testing project. | ||||
|  * | ||||
|  * This is free and unencumbered software released into the public domain. | ||||
|  */ | ||||
|  | ||||
| #include "example.h" | ||||
|  | ||||
| #include <godot_cpp/core/class_db.hpp> | ||||
|  | ||||
| #include <godot_cpp/classes/global_constants.hpp> | ||||
| #include <godot_cpp/classes/label.hpp> | ||||
| #include <godot_cpp/variant/utility_functions.hpp> | ||||
|  | ||||
| using namespace godot; | ||||
|  | ||||
| int ExampleRef::instance_count = 0; | ||||
| int ExampleRef::last_id = 0; | ||||
|  | ||||
| int ExampleRef::get_id() const { | ||||
| 	return id; | ||||
| } | ||||
|  | ||||
| void ExampleRef::_bind_methods() { | ||||
| 	ClassDB::bind_method(D_METHOD("get_id"), &ExampleRef::get_id); | ||||
| } | ||||
|  | ||||
| ExampleRef::ExampleRef() { | ||||
| 	id = ++last_id; | ||||
| 	instance_count++; | ||||
|  | ||||
| 	UtilityFunctions::print("ExampleRef ", itos(id), " created, current instance count: ", itos(instance_count)); | ||||
| } | ||||
|  | ||||
| ExampleRef::~ExampleRef() { | ||||
| 	instance_count--; | ||||
| 	UtilityFunctions::print("ExampleRef ", itos(id), " destroyed, current instance count: ", itos(instance_count)); | ||||
| } | ||||
|  | ||||
| int Example::test_static(int p_a, int p_b) { | ||||
| 	return p_a + p_b; | ||||
| } | ||||
|  | ||||
| void Example::test_static2() { | ||||
| 	UtilityFunctions::print("  void static"); | ||||
| } | ||||
|  | ||||
| int Example::def_args(int p_a, int p_b) { | ||||
| 	return p_a + p_b; | ||||
| } | ||||
|  | ||||
|  | ||||
|  | ||||
| bool Example::_set(const StringName &p_name, const Variant &p_value) { | ||||
| 	String name = p_name; | ||||
| 	if (name.begins_with("dproperty")) { | ||||
| 		int64_t index = name.get_slicec('_', 1).to_int(); | ||||
| 		dprop[index] = p_value; | ||||
| 		return true; | ||||
| 	} | ||||
| 	if (name == "property_from_list") { | ||||
| 		property_from_list = p_value; | ||||
| 		return true; | ||||
| 	} | ||||
| 	return false; | ||||
| } | ||||
|  | ||||
| bool Example::_get(const StringName &p_name, Variant &r_ret) const { | ||||
| 	String name = p_name; | ||||
| 	if (name.begins_with("dproperty")) { | ||||
| 		int64_t index = name.get_slicec('_', 1).to_int(); | ||||
| 		r_ret = dprop[index]; | ||||
| 		return true; | ||||
| 	} | ||||
| 	if (name == "property_from_list") { | ||||
| 		r_ret = property_from_list; | ||||
| 		return true; | ||||
| 	} | ||||
| 	return false; | ||||
| } | ||||
|  | ||||
| String Example::_to_string() const { | ||||
| 	return "[ GDExtension::Example <--> Instance ID:" + uitos(get_instance_id()) + " ]"; | ||||
| } | ||||
|  | ||||
| void Example::_get_property_list(List<PropertyInfo> *p_list) const { | ||||
| 	p_list->push_back(PropertyInfo(Variant::VECTOR3, "property_from_list")); | ||||
| 	for (int i = 0; i < 3; i++) { | ||||
| 		p_list->push_back(PropertyInfo(Variant::VECTOR2, "dproperty_" + itos(i))); | ||||
| 	} | ||||
| } | ||||
|  | ||||
| bool Example::_property_can_revert(const StringName &p_name) const { | ||||
| 	if (p_name == StringName("property_from_list") && property_from_list != Vector3(42, 42, 42)) { | ||||
| 		return true; | ||||
| 	} else { | ||||
| 		return false; | ||||
| 	} | ||||
| }; | ||||
|  | ||||
| bool Example::_property_get_revert(const StringName &p_name, Variant &r_property) const { | ||||
| 	if (p_name == StringName("property_from_list")) { | ||||
| 		r_property = Vector3(42, 42, 42); | ||||
| 		return true; | ||||
| 	} else { | ||||
| 		return false; | ||||
| 	} | ||||
| }; | ||||
|  | ||||
| void Example::_bind_methods() { | ||||
| 	// Methods. | ||||
| 	ClassDB::bind_method(D_METHOD("simple_func"), &Example::simple_func); | ||||
| 	ClassDB::bind_method(D_METHOD("simple_const_func"), &Example::simple_const_func); | ||||
| 	ClassDB::bind_method(D_METHOD("return_something"), &Example::return_something); | ||||
| 	ClassDB::bind_method(D_METHOD("return_something_const"), &Example::return_something_const); | ||||
| 	ClassDB::bind_method(D_METHOD("return_empty_ref"), &Example::return_empty_ref); | ||||
| 	ClassDB::bind_method(D_METHOD("return_extended_ref"), &Example::return_extended_ref); | ||||
| 	ClassDB::bind_method(D_METHOD("extended_ref_checks", "ref"), &Example::extended_ref_checks); | ||||
|  | ||||
| 	ClassDB::bind_method(D_METHOD("test_array"), &Example::test_array); | ||||
| 	ClassDB::bind_method(D_METHOD("test_tarray_arg", "array"), &Example::test_tarray_arg); | ||||
| 	ClassDB::bind_method(D_METHOD("test_tarray"), &Example::test_tarray); | ||||
| 	ClassDB::bind_method(D_METHOD("test_dictionary"), &Example::test_dictionary); | ||||
| 	ClassDB::bind_method(D_METHOD("test_node_argument"), &Example::test_node_argument); | ||||
| 	ClassDB::bind_method(D_METHOD("test_string_ops"), &Example::test_string_ops); | ||||
| 	ClassDB::bind_method(D_METHOD("test_vector_ops"), &Example::test_vector_ops); | ||||
|  | ||||
| 	ClassDB::bind_method(D_METHOD("test_bitfield", "flags"), &Example::test_bitfield); | ||||
|  | ||||
| 	ClassDB::bind_method(D_METHOD("def_args", "a", "b"), &Example::def_args, DEFVAL(100), DEFVAL(200)); | ||||
|  | ||||
| 	ClassDB::bind_static_method("Example", D_METHOD("test_static", "a", "b"), &Example::test_static); | ||||
| 	ClassDB::bind_static_method("Example", D_METHOD("test_static2"), &Example::test_static2); | ||||
|  | ||||
| 	{ | ||||
| 		MethodInfo mi; | ||||
| 		mi.arguments.push_back(PropertyInfo(Variant::STRING, "some_argument")); | ||||
| 		mi.name = "varargs_func"; | ||||
| 		ClassDB::bind_vararg_method(METHOD_FLAGS_DEFAULT, "varargs_func", &Example::varargs_func, mi); | ||||
| 	} | ||||
|  | ||||
| 	{ | ||||
| 		MethodInfo mi; | ||||
| 		mi.arguments.push_back(PropertyInfo(Variant::STRING, "some_argument")); | ||||
| 		mi.name = "varargs_func_nv"; | ||||
| 		ClassDB::bind_vararg_method(METHOD_FLAGS_DEFAULT, "varargs_func_nv", &Example::varargs_func_nv, mi); | ||||
| 	} | ||||
|  | ||||
| 	{ | ||||
| 		MethodInfo mi; | ||||
| 		mi.arguments.push_back(PropertyInfo(Variant::STRING, "some_argument")); | ||||
| 		mi.name = "varargs_func_void"; | ||||
| 		ClassDB::bind_vararg_method(METHOD_FLAGS_DEFAULT, "varargs_func_void", &Example::varargs_func_void, mi); | ||||
| 	} | ||||
|  | ||||
| 	// Properties. | ||||
| 	ADD_GROUP("Test group", "group_"); | ||||
| 	ADD_SUBGROUP("Test subgroup", "group_subgroup_"); | ||||
|  | ||||
| 	ClassDB::bind_method(D_METHOD("get_custom_position"), &Example::get_custom_position); | ||||
| 	ClassDB::bind_method(D_METHOD("get_v4"), &Example::get_v4); | ||||
| 	ClassDB::bind_method(D_METHOD("set_custom_position", "position"), &Example::set_custom_position); | ||||
| 	ADD_PROPERTY(PropertyInfo(Variant::VECTOR2, "group_subgroup_custom_position"), "set_custom_position", "get_custom_position"); | ||||
|  | ||||
| 	// Signals. | ||||
| 	ADD_SIGNAL(MethodInfo("custom_signal", PropertyInfo(Variant::STRING, "name"), PropertyInfo(Variant::INT, "value"))); | ||||
| 	ClassDB::bind_method(D_METHOD("emit_custom_signal", "name", "value"), &Example::emit_custom_signal); | ||||
|  | ||||
| 	// Constants. | ||||
| 	BIND_ENUM_CONSTANT(FIRST); | ||||
| 	BIND_ENUM_CONSTANT(ANSWER_TO_EVERYTHING); | ||||
|  | ||||
| 	BIND_BITFIELD_FLAG(FLAG_ONE); | ||||
| 	BIND_BITFIELD_FLAG(FLAG_TWO); | ||||
|  | ||||
| 	BIND_CONSTANT(CONSTANT_WITHOUT_ENUM); | ||||
| 	BIND_ENUM_CONSTANT(OUTSIDE_OF_CLASS); | ||||
| } | ||||
|  | ||||
| Example::Example() { | ||||
| 	UtilityFunctions::print("Constructor."); | ||||
| } | ||||
|  | ||||
| Example::~Example() { | ||||
| 	UtilityFunctions::print("Destructor."); | ||||
| } | ||||
|  | ||||
| // Methods. | ||||
| void Example::simple_func() { | ||||
| 	UtilityFunctions::print("  Simple func called."); | ||||
| } | ||||
|  | ||||
| void Example::simple_const_func() const { | ||||
| 	UtilityFunctions::print("  Simple const func called."); | ||||
| } | ||||
|  | ||||
| String Example::return_something(const String &base) { | ||||
| 	UtilityFunctions::print("  Return something called."); | ||||
| 	return base; | ||||
| } | ||||
|  | ||||
| Viewport *Example::return_something_const() const { | ||||
| 	UtilityFunctions::print("  Return something const called."); | ||||
| 	if (is_inside_tree()) { | ||||
| 		Viewport *result = get_viewport(); | ||||
| 		return result; | ||||
| 	} | ||||
| 	return nullptr; | ||||
| } | ||||
|  | ||||
| Ref<ExampleRef> Example::return_empty_ref() const { | ||||
| 	Ref<ExampleRef> ref; | ||||
| 	return ref; | ||||
| } | ||||
|  | ||||
| ExampleRef *Example::return_extended_ref() const { | ||||
| 	// You can instance and return a refcounted object like this, but keep in mind that refcounting starts with the returned object | ||||
| 	// and it will be destroyed when all references are destroyed. If you store this pointer you run the risk of having a pointer | ||||
| 	// to a destroyed object. | ||||
| 	return memnew(ExampleRef()); | ||||
| } | ||||
|  | ||||
| Example *Example::test_node_argument(Example *p_node) const { | ||||
| 	UtilityFunctions::print("  Test node argument called with ", p_node ? String::num(p_node->get_instance_id()) : "null"); | ||||
| 	return p_node; | ||||
| } | ||||
|  | ||||
| Ref<ExampleRef> Example::extended_ref_checks(Ref<ExampleRef> p_ref) const { | ||||
| 	// This is therefor the prefered way of instancing and returning a refcounted object: | ||||
| 	Ref<ExampleRef> ref; | ||||
| 	ref.instantiate(); | ||||
|  | ||||
| 	UtilityFunctions::print("  Example ref checks called with value: ", p_ref->get_instance_id(), ", returning value: ", ref->get_instance_id()); | ||||
| 	return ref; | ||||
| } | ||||
|  | ||||
| Variant Example::varargs_func(const Variant **args, GDExtensionInt arg_count, GDExtensionCallError &error) { | ||||
| 	UtilityFunctions::print("  Varargs (Variant return) called with ", String::num((double)arg_count), " arguments"); | ||||
| 	return arg_count; | ||||
| } | ||||
|  | ||||
| int Example::varargs_func_nv(const Variant **args, GDExtensionInt arg_count, GDExtensionCallError &error) { | ||||
| 	UtilityFunctions::print("  Varargs (int return) called with ", String::num((double)arg_count), " arguments"); | ||||
| 	return 42; | ||||
| } | ||||
|  | ||||
| void Example::varargs_func_void(const Variant **args, GDExtensionInt arg_count, GDExtensionCallError &error) { | ||||
| 	UtilityFunctions::print("  Varargs (no return) called with ", String::num((double)arg_count), " arguments"); | ||||
| } | ||||
|  | ||||
| void Example::emit_custom_signal(const String &name, int value) { | ||||
| 	emit_signal("custom_signal", name, value); | ||||
| } | ||||
|  | ||||
| Array Example::test_array() const { | ||||
| 	Array arr; | ||||
|  | ||||
| 	arr.resize(2); | ||||
| 	arr[0] = Variant(1); | ||||
| 	arr[1] = Variant(2); | ||||
|  | ||||
| 	return arr; | ||||
| } | ||||
|  | ||||
| String Example::test_string_ops() const { | ||||
| 	String s = String("A"); | ||||
| 	s += "B"; | ||||
| 	s += "C"; | ||||
| 	s += char32_t(0x010E); | ||||
| 	s = s + "E"; | ||||
| 	return s; | ||||
| } | ||||
|  | ||||
| int Example::test_vector_ops() const { | ||||
| 	PackedInt32Array arr; | ||||
| 	arr.push_back(10); | ||||
| 	arr.push_back(20); | ||||
| 	arr.push_back(30); | ||||
| 	arr.push_back(45); | ||||
| 	int ret = 0; | ||||
| 	for (const int32_t &E : arr) { | ||||
| 		ret += E; | ||||
| 	} | ||||
| 	return ret; | ||||
| } | ||||
|  | ||||
| void Example::test_tarray_arg(const TypedArray<int64_t> &p_array) { | ||||
| 	for (int i = 0; i < p_array.size(); i++) { | ||||
| 		UtilityFunctions::print(p_array[i]); | ||||
| 	} | ||||
| } | ||||
|  | ||||
| TypedArray<Vector2> Example::test_tarray() const { | ||||
| 	TypedArray<Vector2> arr; | ||||
|  | ||||
| 	arr.resize(2); | ||||
| 	arr[0] = Vector2(1, 2); | ||||
| 	arr[1] = Vector2(2, 3); | ||||
|  | ||||
| 	return arr; | ||||
| } | ||||
|  | ||||
| Dictionary Example::test_dictionary() const { | ||||
| 	Dictionary dict; | ||||
|  | ||||
| 	dict["hello"] = "world"; | ||||
| 	dict["foo"] = "bar"; | ||||
|  | ||||
| 	return dict; | ||||
| } | ||||
|  | ||||
| BitField<Example::Flags> Example::test_bitfield(BitField<Flags> flags) { | ||||
| 	UtilityFunctions::print("  Got BitField: ", String::num_int64(flags)); | ||||
| 	return flags; | ||||
| } | ||||
|  | ||||
| // Properties. | ||||
| void Example::set_custom_position(const Vector2 &pos) { | ||||
| 	custom_position = pos; | ||||
| } | ||||
|  | ||||
| Vector2 Example::get_custom_position() const { | ||||
| 	return custom_position; | ||||
| } | ||||
|  | ||||
| Vector4 Example::get_v4() const { | ||||
| 	return Vector4(1.2, 3.4, 5.6, 7.8); | ||||
| } | ||||
|  | ||||
| // Virtual function override. | ||||
| bool Example::_has_point(const Vector2 &point) const { | ||||
| 	Label *label = get_node<Label>("Label"); | ||||
| 	label->set_text("Got point: " + Variant(point).stringify()); | ||||
|  | ||||
| 	return false; | ||||
| } | ||||
| void Example::_ready() { | ||||
| 	UtilityFunctions::print("this is a test"); | ||||
| } | ||||
							
								
								
									
										150
									
								
								src/example.h
									
									
									
									
									
								
							
							
						
						
									
										150
									
								
								src/example.h
									
									
									
									
									
								
							| @@ -1,150 +0,0 @@ | ||||
| /* godot-cpp integration testing project. | ||||
|  * | ||||
|  * This is free and unencumbered software released into the public domain. | ||||
|  */ | ||||
|  | ||||
| #ifndef EXAMPLE_CLASS_H | ||||
| #define EXAMPLE_CLASS_H | ||||
|  | ||||
| // We don't need windows.h in this example plugin but many others do, and it can | ||||
| // lead to annoying situations due to the ton of macros it defines. | ||||
| // So we include it and make sure CI warns us if we use something that conflicts | ||||
| // with a Windows define. | ||||
| #ifdef WIN32 | ||||
| #include <windows.h> | ||||
| #endif | ||||
|  | ||||
| #include <godot_cpp/classes/control.hpp> | ||||
| #include <godot_cpp/classes/global_constants.hpp> | ||||
| #include <godot_cpp/classes/viewport.hpp> | ||||
|  | ||||
| #include <godot_cpp/core/binder_common.hpp> | ||||
|  | ||||
| using namespace godot; | ||||
|  | ||||
| class ExampleRef : public RefCounted { | ||||
| 	GDCLASS(ExampleRef, RefCounted); | ||||
|  | ||||
| private: | ||||
| 	static int instance_count; | ||||
| 	static int last_id; | ||||
|  | ||||
| 	int id; | ||||
|  | ||||
| protected: | ||||
| 	static void _bind_methods(); | ||||
|  | ||||
| public: | ||||
| 	ExampleRef(); | ||||
| 	~ExampleRef(); | ||||
|  | ||||
| 	int get_id() const; | ||||
| }; | ||||
|  | ||||
| class ExampleMin : public Control { | ||||
| 	GDCLASS(ExampleMin, Control); | ||||
|  | ||||
| protected: | ||||
| 	static void _bind_methods(){}; | ||||
| }; | ||||
|  | ||||
| class Example : public Control { | ||||
| 	GDCLASS(Example, Control); | ||||
|  | ||||
| protected: | ||||
| 	static void _bind_methods(); | ||||
|  | ||||
| 	void _notification(int p_what); | ||||
| 	bool _set(const StringName &p_name, const Variant &p_value); | ||||
| 	bool _get(const StringName &p_name, Variant &r_ret) const; | ||||
| 	void _get_property_list(List<PropertyInfo> *p_list) const; | ||||
| 	bool _property_can_revert(const StringName &p_name) const; | ||||
| 	bool _property_get_revert(const StringName &p_name, Variant &r_property) const; | ||||
|  | ||||
| 	String _to_string() const; | ||||
|  | ||||
| private: | ||||
| 	Vector2 custom_position; | ||||
| 	Vector3 property_from_list; | ||||
| 	Vector2 dprop[3]; | ||||
|  | ||||
| public: | ||||
| 	// Constants. | ||||
| 	enum Constants { | ||||
| 		FIRST, | ||||
| 		ANSWER_TO_EVERYTHING = 42, | ||||
| 	}; | ||||
|  | ||||
| 	enum Flags { | ||||
| 		FLAG_ONE = 1, | ||||
| 		FLAG_TWO = 2, | ||||
| 	}; | ||||
|  | ||||
| 	enum { | ||||
| 		CONSTANT_WITHOUT_ENUM = 314, | ||||
| 	}; | ||||
|  | ||||
| 	Example(); | ||||
| 	~Example(); | ||||
|  | ||||
| 	// Functions. | ||||
| 	void simple_func(); | ||||
| 	void simple_const_func() const; | ||||
| 	String return_something(const String &base); | ||||
| 	Viewport *return_something_const() const; | ||||
| 	Ref<ExampleRef> return_empty_ref() const; | ||||
| 	ExampleRef *return_extended_ref() const; | ||||
| 	Ref<ExampleRef> extended_ref_checks(Ref<ExampleRef> p_ref) const; | ||||
| 	Variant varargs_func(const Variant **args, GDExtensionInt arg_count, GDExtensionCallError &error); | ||||
| 	int varargs_func_nv(const Variant **args, GDExtensionInt arg_count, GDExtensionCallError &error); | ||||
| 	void varargs_func_void(const Variant **args, GDExtensionInt arg_count, GDExtensionCallError &error); | ||||
| 	void emit_custom_signal(const String &name, int value); | ||||
| 	int def_args(int p_a = 100, int p_b = 200); | ||||
|  | ||||
| 	Array test_array() const; | ||||
| 	void test_tarray_arg(const TypedArray<int64_t> &p_array); | ||||
| 	TypedArray<Vector2> test_tarray() const; | ||||
| 	Dictionary test_dictionary() const; | ||||
| 	Example *test_node_argument(Example *p_node) const; | ||||
| 	String test_string_ops() const; | ||||
| 	int test_vector_ops() const; | ||||
|  | ||||
| 	BitField<Flags> test_bitfield(BitField<Flags> flags); | ||||
|  | ||||
| 	// Property. | ||||
| 	void set_custom_position(const Vector2 &pos); | ||||
| 	Vector2 get_custom_position() const; | ||||
| 	Vector4 get_v4() const; | ||||
|  | ||||
| 	// Static method. | ||||
| 	static int test_static(int p_a, int p_b); | ||||
| 	static void test_static2(); | ||||
|  | ||||
| 	// Virtual function override (no need to bind manually). | ||||
| 	virtual bool _has_point(const Vector2 &point) const override; | ||||
|     void _ready(); | ||||
| }; | ||||
|  | ||||
| VARIANT_ENUM_CAST(Example::Constants); | ||||
| VARIANT_BITFIELD_CAST(Example::Flags); | ||||
|  | ||||
| enum EnumWithoutClass { | ||||
| 	OUTSIDE_OF_CLASS = 512 | ||||
| }; | ||||
| VARIANT_ENUM_CAST(EnumWithoutClass); | ||||
|  | ||||
| class ExampleVirtual : public Object { | ||||
| 	GDCLASS(ExampleVirtual, Object); | ||||
|  | ||||
| protected: | ||||
| 	static void _bind_methods() {} | ||||
| }; | ||||
|  | ||||
| class ExampleAbstract : public Object { | ||||
| 	GDCLASS(ExampleAbstract, Object); | ||||
|  | ||||
| protected: | ||||
| 	static void _bind_methods() {} | ||||
| }; | ||||
|  | ||||
| #endif // EXAMPLE_CLASS_H | ||||
							
								
								
									
										24
									
								
								src/gdexample.cpp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										24
									
								
								src/gdexample.cpp
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,24 @@ | ||||
| #include "gdexample.h" | ||||
| #include <godot_cpp/core/class_db.hpp> | ||||
|  | ||||
| using namespace godot; | ||||
|  | ||||
| void GDExample::_bind_methods() { | ||||
| } | ||||
|  | ||||
| GDExample::GDExample() { | ||||
|     // initialize any variables here | ||||
|     time_passed = 0.0; | ||||
| } | ||||
|  | ||||
| GDExample::~GDExample() { | ||||
|     // add your cleanup here | ||||
| } | ||||
|  | ||||
| void GDExample::_process(float delta) { | ||||
|     time_passed += delta; | ||||
|  | ||||
|     Vector2 new_position = Vector2(10.0 + (10.0 * sin(time_passed * 2.0)), 10.0 + (10.0 * cos(time_passed * 1.5))); | ||||
|  | ||||
|     set_position(new_position); | ||||
| } | ||||
							
								
								
									
										26
									
								
								src/gdexample.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										26
									
								
								src/gdexample.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,26 @@ | ||||
| #ifndef GDEXAMPLE_H | ||||
| #define GDEXAMPLE_H | ||||
|  | ||||
| #include <godot_cpp/classes/sprite2d.hpp> | ||||
|  | ||||
| namespace godot { | ||||
|  | ||||
| class GDExample : public Sprite2D { | ||||
|     GDCLASS(GDExample, Sprite2D) | ||||
|  | ||||
| private: | ||||
|     float time_passed; | ||||
|  | ||||
| protected: | ||||
|     static void _bind_methods(); | ||||
|  | ||||
| public: | ||||
|     GDExample(); | ||||
|     ~GDExample(); | ||||
|  | ||||
|     void _process(float delta); | ||||
| }; | ||||
|  | ||||
| } | ||||
|  | ||||
| #endif | ||||
| @@ -1,19 +1,12 @@ | ||||
| /* godot-cpp integration testing project. | ||||
|  * | ||||
|  * This is free and unencumbered software released into the public domain. | ||||
|  */ | ||||
|  | ||||
| #include "register_types.h" | ||||
|  | ||||
| #include "gdexample.h" | ||||
|  | ||||
| #include <gdextension_interface.h> | ||||
|  | ||||
| #include <godot_cpp/core/class_db.hpp> | ||||
| #include <godot_cpp/core/defs.hpp> | ||||
| #include <godot_cpp/core/class_db.hpp> | ||||
| #include <godot_cpp/godot.hpp> | ||||
|  | ||||
| #include "example.h" | ||||
| #include "tests.h" | ||||
|  | ||||
| using namespace godot; | ||||
|  | ||||
| void initialize_example_module(ModuleInitializationLevel p_level) { | ||||
| @@ -21,11 +14,7 @@ void initialize_example_module(ModuleInitializationLevel p_level) { | ||||
|         return; | ||||
|     } | ||||
|  | ||||
| 	ClassDB::register_class<ExampleRef>(); | ||||
| 	ClassDB::register_class<ExampleMin>(); | ||||
| 	ClassDB::register_class<Example>(); | ||||
| 	ClassDB::register_class<ExampleVirtual>(true); | ||||
| 	ClassDB::register_abstract_class<ExampleAbstract>(); | ||||
|     ClassDB::register_class<GDExample>(); | ||||
| } | ||||
|  | ||||
| void uninitialize_example_module(ModuleInitializationLevel p_level) { | ||||
| @@ -36,7 +25,7 @@ void uninitialize_example_module(ModuleInitializationLevel p_level) { | ||||
|  | ||||
| extern "C" { | ||||
| // Initialization. | ||||
| GDExtensionBool GDE_EXPORT discordrpcgd_library_init(const GDExtensionInterface *p_interface, GDExtensionClassLibraryPtr p_library, GDExtensionInitialization *r_initialization) { | ||||
| GDExtensionBool GDE_EXPORT discordrpcgd_library_init(const GDExtensionInterface *p_interface, const GDExtensionClassLibraryPtr p_library, GDExtensionInitialization *r_initialization) { | ||||
|     godot::GDExtensionBinding::InitObject init_obj(p_interface, p_library, r_initialization); | ||||
|  | ||||
|     init_obj.register_initializer(initialize_example_module); | ||||
|   | ||||
| @@ -1,16 +1,7 @@ | ||||
| /* godot-cpp integration testing project. | ||||
|  * | ||||
|  * This is free and unencumbered software released into the public domain. | ||||
|  */ | ||||
| #ifndef GDEXAMPLE_REGISTER_TYPES_H | ||||
| #define GDEXAMPLE_REGISTER_TYPES_H | ||||
|  | ||||
| #ifndef EXAMPLE_REGISTER_TYPES_H | ||||
| #define EXAMPLE_REGISTER_TYPES_H | ||||
| void initialize_example_module(); | ||||
| void uninitialize_example_module(); | ||||
|  | ||||
| #include <godot_cpp/core/class_db.hpp> | ||||
|  | ||||
| using namespace godot; | ||||
|  | ||||
| void initialize_example_module(ModuleInitializationLevel p_level); | ||||
| void uninitialize_example_module(ModuleInitializationLevel p_level); | ||||
|  | ||||
| #endif // EXAMPLE_REGISTER_TYPES_H | ||||
| #endif // GDEXAMPLE_REGISTER_TYPES_H | ||||
							
								
								
									
										28
									
								
								src/tests.h
									
									
									
									
									
								
							
							
						
						
									
										28
									
								
								src/tests.h
									
									
									
									
									
								
							| @@ -1,28 +0,0 @@ | ||||
| /* godot-cpp integration testing project. | ||||
|  * | ||||
|  * This is free and unencumbered software released into the public domain. | ||||
|  */ | ||||
|  | ||||
| #ifndef TESTS_H | ||||
| #define TESTS_H | ||||
|  | ||||
| #include "godot_cpp/templates/cowdata.hpp" | ||||
| #include "godot_cpp/templates/hash_map.hpp" | ||||
| #include "godot_cpp/templates/hash_set.hpp" | ||||
| #include "godot_cpp/templates/hashfuncs.hpp" | ||||
| #include "godot_cpp/templates/list.hpp" | ||||
| #include "godot_cpp/templates/pair.hpp" | ||||
| #include "godot_cpp/templates/rb_map.hpp" | ||||
| #include "godot_cpp/templates/rb_set.hpp" | ||||
| #include "godot_cpp/templates/rid_owner.hpp" | ||||
| #include "godot_cpp/templates/safe_refcount.hpp" | ||||
| #include "godot_cpp/templates/search_array.hpp" | ||||
| #include "godot_cpp/templates/self_list.hpp" | ||||
| #include "godot_cpp/templates/sort_array.hpp" | ||||
| #include "godot_cpp/templates/spin_lock.hpp" | ||||
| #include "godot_cpp/templates/thread_work_pool.hpp" | ||||
| #include "godot_cpp/templates/vector.hpp" | ||||
| #include "godot_cpp/templates/vmap.hpp" | ||||
| #include "godot_cpp/templates/vset.hpp" | ||||
|  | ||||
| #endif // TESTS_H | ||||
		Reference in New Issue
	
	Block a user