From dc2493e7525bb7633f697ef10f72b72b46222249 Mon Sep 17 00:00:00 2001 From: Andy Belle-Isle Date: Fri, 30 Aug 2019 00:45:36 -0400 Subject: Forget what I said, I just need to change git attributes to mark for vendor --- lib/sol2/examples/source/unique_ptr.cpp | 89 +++++++++++++++++++++++++++++++++ 1 file changed, 89 insertions(+) create mode 100644 lib/sol2/examples/source/unique_ptr.cpp (limited to 'lib/sol2/examples/source/unique_ptr.cpp') diff --git a/lib/sol2/examples/source/unique_ptr.cpp b/lib/sol2/examples/source/unique_ptr.cpp new file mode 100644 index 0000000..7824907 --- /dev/null +++ b/lib/sol2/examples/source/unique_ptr.cpp @@ -0,0 +1,89 @@ +#define SOL_ALL_SAFETIES_ON 1 +#include + +#include "assert.hpp" + +#include + +struct my_type { + int value = 10; + + my_type() { + std::cout << "my_type at " << static_cast(this) << " being default constructed!" << std::endl; + } + + my_type(const my_type& other) : value(other.value) { + std::cout << "my_type at " << static_cast(this) << " being copy constructed!" << std::endl; + } + + my_type(my_type&& other) : value(other.value) { + std::cout << "my_type at " << static_cast(this) << " being move-constructed!" << std::endl; + } + + my_type& operator=(const my_type& other) { + value = other.value; + std::cout << "my_type at " << static_cast(this) << " being copy-assigned to!" << std::endl; + return *this; + } + + my_type& operator=(my_type&& other) { + value = other.value; + std::cout << "my_type at " << static_cast(this) << " being move-assigned to!" << std::endl; + return *this; + } + + ~my_type() { + std::cout << "my_type at " << static_cast(this) << " being destructed!" << std::endl; + } +}; + +int main() { + + std::cout << "=== unique_ptr support ===" << std::endl; + + sol::state lua; + lua.new_usertype("my_type", + "value", &my_type::value + ); + { + std::unique_ptr unique = std::make_unique(); + lua["unique"] = std::move(unique); + } + { + std::cout << "getting reference to unique_ptr..." << std::endl; + std::unique_ptr& ref_to_unique_ptr = lua["unique"]; + my_type& ref_to_my_type = lua["unique"]; + my_type* ptr_to_my_type = lua["unique"]; + + c_assert(ptr_to_my_type == ref_to_unique_ptr.get()); + c_assert(&ref_to_my_type == ref_to_unique_ptr.get()); + c_assert(ref_to_unique_ptr->value == 10); + + // script affects all of them equally + lua.script("unique.value = 20"); + + c_assert(ptr_to_my_type->value == 20); + c_assert(ref_to_my_type.value == 20); + c_assert(ref_to_unique_ptr->value == 20); + } + { + std::cout << "getting copy of unique_ptr..." << std::endl; + my_type copy_of_value = lua["unique"]; + + c_assert(copy_of_value.value == 20); + + // script still affects pointer, but does not affect copy of `my_type` + lua.script("unique.value = 30"); + + c_assert(copy_of_value.value == 20); + } + // set to nil and collect garbage to destroy it + lua.script("unique = nil"); + lua.collect_garbage(); + lua.collect_garbage(); + + std::cout << "garbage has been collected" << std::endl; + std::cout << std::endl; + + return 0; +} -- cgit v1.2.3