Fix moves of any when value isInBuffer
This was copying the pointer to the other's value in other.buffer.
This commit is contained in:
parent
2f607e077a
commit
f0c28f93dd
@ -85,7 +85,13 @@ any::any(const any& other) noexcept : type(other.type) {
|
||||
}
|
||||
}
|
||||
|
||||
any::any(any&& other) noexcept : value(other.value), type(other.type) {
|
||||
any::any(any&& other) noexcept : type(other.type) {
|
||||
if (other.isInBuffer(other.value)) {
|
||||
alloc(type->size(), type->alignment());
|
||||
type->copyConstruct(value, other.value);
|
||||
} else {
|
||||
value = other.value;
|
||||
}
|
||||
other.value = nullptr;
|
||||
other.type = nullptr;
|
||||
}
|
||||
@ -110,8 +116,14 @@ any& any::operator=(const any& rhs) {
|
||||
}
|
||||
|
||||
any& any::operator=(any&& rhs) noexcept {
|
||||
value = rhs.value;
|
||||
reset();
|
||||
type = rhs.type;
|
||||
if (rhs.isInBuffer(rhs.value)) {
|
||||
alloc(type->size(), type->alignment());
|
||||
type->copyConstruct(value, rhs.value);
|
||||
} else {
|
||||
value = rhs.value;
|
||||
}
|
||||
rhs.value = nullptr;
|
||||
rhs.type = nullptr;
|
||||
return *this;
|
||||
|
@ -40,6 +40,7 @@ TEST(Any, EmptyConstruct) {
|
||||
ASSERT_FALSE(any.is<dap::integer>());
|
||||
ASSERT_FALSE(any.is<dap::number>());
|
||||
ASSERT_FALSE(any.is<dap::object>());
|
||||
ASSERT_FALSE(any.is<dap::string>());
|
||||
ASSERT_FALSE(any.is<dap::array<dap::integer>>());
|
||||
ASSERT_FALSE(any.is<dap::AnyTestObject>());
|
||||
}
|
||||
@ -62,6 +63,12 @@ TEST(Any, Number) {
|
||||
ASSERT_EQ(any.get<dap::number>(), dap::number(123.0f));
|
||||
}
|
||||
|
||||
TEST(Any, String) {
|
||||
dap::any any(dap::string("hello world"));
|
||||
ASSERT_TRUE(any.is<dap::string>());
|
||||
ASSERT_EQ(any.get<dap::string>(), dap::string("hello world"));
|
||||
}
|
||||
|
||||
TEST(Any, Array) {
|
||||
using array = dap::array<dap::integer>;
|
||||
dap::any any(array({10, 20, 30}));
|
||||
@ -116,6 +123,12 @@ TEST(Any, Assign) {
|
||||
ASSERT_TRUE(any.is<dap::AnyTestObject>());
|
||||
ASSERT_EQ(any.get<dap::AnyTestObject>().i, 5);
|
||||
ASSERT_EQ(any.get<dap::AnyTestObject>().n, 3.0);
|
||||
any = dap::string("hello world");
|
||||
ASSERT_FALSE(any.is<dap::integer>());
|
||||
ASSERT_FALSE(any.is<dap::boolean>());
|
||||
ASSERT_FALSE(any.is<dap::AnyTestObject>());
|
||||
ASSERT_TRUE(any.is<dap::string>());
|
||||
ASSERT_EQ(any.get<dap::string>(), dap::string("hello world"));
|
||||
}
|
||||
|
||||
TEST(Any, Reset) {
|
||||
|
Loading…
x
Reference in New Issue
Block a user