diff --git a/generator/templates/apicpp.h b/generator/templates/apicpp.h index af142b04c0..87bd71b5e7 100644 --- a/generator/templates/apicpp.h +++ b/generator/templates/apicpp.h @@ -97,6 +97,15 @@ namespace dawn { return static_cast(*this); } + ObjectBase(nullptr_t) {} + Derived& operator=(nullptr_t) { + if (mHandle != nullptr) { + Derived::DawnRelease(mHandle); + mHandle = nullptr; + } + return static_cast(*this); + } + explicit operator bool() const { return mHandle != nullptr; } diff --git a/src/tests/unittests/ObjectBaseTests.cpp b/src/tests/unittests/ObjectBaseTests.cpp index 2c9dccbffb..b42920f157 100644 --- a/src/tests/unittests/ObjectBaseTests.cpp +++ b/src/tests/unittests/ObjectBaseTests.cpp @@ -177,3 +177,21 @@ TEST(ObjectBase, MoveAssignmentSelf) { ASSERT_EQ(obj.Get(), &refcount); ASSERT_EQ(refcount, 2); } + +// Test the constructor using nullptr +TEST(ObjectBase, NullptrConstructor) { + Object obj(nullptr); + ASSERT_EQ(obj.Get(), nullptr); +} + +// Test assigning nullptr to the object +TEST(ObjectBase, AssignNullptr) { + int refcount = 1; + + Object obj(&refcount); + ASSERT_EQ(refcount, 2); + + obj = nullptr; + ASSERT_EQ(refcount, 1); +} +