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"] | [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"] | [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="."] | [node name="Button" type="Button" parent="."] | ||||||
| offset_right = 79.0 | offset_right = 79.0 | ||||||
| offset_bottom = 29.0 | offset_bottom = 29.0 | ||||||
| text = "Click me!" | 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,48 +1,37 @@ | |||||||
| /* godot-cpp integration testing project. |  | ||||||
|  * |  | ||||||
|  * This is free and unencumbered software released into the public domain. |  | ||||||
|  */ |  | ||||||
|  |  | ||||||
| #include "register_types.h" | #include "register_types.h" | ||||||
|  |  | ||||||
|  | #include "gdexample.h" | ||||||
|  |  | ||||||
| #include <gdextension_interface.h> | #include <gdextension_interface.h> | ||||||
|  |  | ||||||
| #include <godot_cpp/core/class_db.hpp> |  | ||||||
| #include <godot_cpp/core/defs.hpp> | #include <godot_cpp/core/defs.hpp> | ||||||
|  | #include <godot_cpp/core/class_db.hpp> | ||||||
| #include <godot_cpp/godot.hpp> | #include <godot_cpp/godot.hpp> | ||||||
|  |  | ||||||
| #include "example.h" |  | ||||||
| #include "tests.h" |  | ||||||
|  |  | ||||||
| using namespace godot; | using namespace godot; | ||||||
|  |  | ||||||
| void initialize_example_module(ModuleInitializationLevel p_level) { | void initialize_example_module(ModuleInitializationLevel p_level) { | ||||||
| 	if (p_level != MODULE_INITIALIZATION_LEVEL_SCENE) { |     if (p_level != MODULE_INITIALIZATION_LEVEL_SCENE) { | ||||||
| 		return; |         return; | ||||||
| 	} |     } | ||||||
|  |  | ||||||
| 	ClassDB::register_class<ExampleRef>(); |     ClassDB::register_class<GDExample>(); | ||||||
| 	ClassDB::register_class<ExampleMin>(); |  | ||||||
| 	ClassDB::register_class<Example>(); |  | ||||||
| 	ClassDB::register_class<ExampleVirtual>(true); |  | ||||||
| 	ClassDB::register_abstract_class<ExampleAbstract>(); |  | ||||||
| } | } | ||||||
|  |  | ||||||
| void uninitialize_example_module(ModuleInitializationLevel p_level) { | void uninitialize_example_module(ModuleInitializationLevel p_level) { | ||||||
| 	if (p_level != MODULE_INITIALIZATION_LEVEL_SCENE) { |     if (p_level != MODULE_INITIALIZATION_LEVEL_SCENE) { | ||||||
| 		return; |         return; | ||||||
| 	} |     } | ||||||
| } | } | ||||||
|  |  | ||||||
| extern "C" { | extern "C" { | ||||||
| // Initialization. | // 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); |     godot::GDExtensionBinding::InitObject init_obj(p_interface, p_library, r_initialization); | ||||||
|  |  | ||||||
| 	init_obj.register_initializer(initialize_example_module); |     init_obj.register_initializer(initialize_example_module); | ||||||
| 	init_obj.register_terminator(uninitialize_example_module); |     init_obj.register_terminator(uninitialize_example_module); | ||||||
| 	init_obj.set_minimum_library_initialization_level(MODULE_INITIALIZATION_LEVEL_SCENE); |     init_obj.set_minimum_library_initialization_level(MODULE_INITIALIZATION_LEVEL_SCENE); | ||||||
|  |  | ||||||
| 	return init_obj.init(); |     return init_obj.init(); | ||||||
| } |  | ||||||
| } | } | ||||||
|  | } | ||||||
| @@ -1,16 +1,7 @@ | |||||||
| /* godot-cpp integration testing project. | #ifndef GDEXAMPLE_REGISTER_TYPES_H | ||||||
|  * | #define GDEXAMPLE_REGISTER_TYPES_H | ||||||
|  * This is free and unencumbered software released into the public domain. |  | ||||||
|  */ |  | ||||||
|  |  | ||||||
| #ifndef EXAMPLE_REGISTER_TYPES_H | void initialize_example_module(); | ||||||
| #define EXAMPLE_REGISTER_TYPES_H | void uninitialize_example_module(); | ||||||
|  |  | ||||||
| #include <godot_cpp/core/class_db.hpp> | #endif // GDEXAMPLE_REGISTER_TYPES_H | ||||||
|  |  | ||||||
| using namespace godot; |  | ||||||
|  |  | ||||||
| void initialize_example_module(ModuleInitializationLevel p_level); |  | ||||||
| void uninitialize_example_module(ModuleInitializationLevel p_level); |  | ||||||
|  |  | ||||||
| #endif // EXAMPLE_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