diff --git a/include/pybind11/detail/smart_holder_poc.h b/include/pybind11/detail/smart_holder_poc.h index 76675bd86..e82b0b9c8 100644 --- a/include/pybind11/detail/smart_holder_poc.h +++ b/include/pybind11/detail/smart_holder_poc.h @@ -240,8 +240,7 @@ to_cout("LOOOK smart_holder reset_vptr_deleter_armed_flag " + std::to_string(__L vptr_del_fptr->armed_flag = armed_flag; } - template - static smart_holder from_raw_ptr_unowned(T *raw_ptr) { + static smart_holder from_raw_ptr_unowned(void *raw_ptr) { to_cout("LOOOK smart_holder from_raw_ptr_unowned " + std::to_string(__LINE__) + " " + __FILE__); smart_holder hld; hld.vptr.reset(raw_ptr, [](void *) {}); @@ -278,7 +277,7 @@ to_cout(""); to_cout("LOOOK smart_holder from_raw_ptr_take_ownership " + std::to_string(__LINE__) + " " + __FILE__); ensure_pointee_is_destructible("from_raw_ptr_take_ownership"); smart_holder hld; - hld.vptr.reset(raw_ptr, make_guarded_builtin_delete(true)); + hld.vptr.reset(static_cast(raw_ptr), make_guarded_builtin_delete(true)); hld.vptr_is_using_builtin_delete = true; hld.is_populated = true; return hld; @@ -328,9 +327,11 @@ to_cout("LOOOK smart_holder from_unique_ptr " + std::to_string(__LINE__) + " " + hld.rtti_uqp_del = &typeid(D); hld.vptr_is_using_builtin_delete = is_std_default_delete(*hld.rtti_uqp_del); if (hld.vptr_is_using_builtin_delete) { - hld.vptr.reset(unq_ptr.get(), make_guarded_builtin_delete(true)); + hld.vptr.reset(static_cast(unq_ptr.get()), + make_guarded_builtin_delete(true)); } else { - hld.vptr.reset(unq_ptr.get(), make_guarded_custom_deleter(true)); + hld.vptr.reset(static_cast(unq_ptr.get()), + make_guarded_custom_deleter(true)); } unq_ptr.release(); hld.is_populated = true; diff --git a/tests/test_class_sh_trampoline_shared_from_this.py b/tests/test_class_sh_trampoline_shared_from_this.py index c654439da..79b3ace9b 100644 --- a/tests/test_class_sh_trampoline_shared_from_this.py +++ b/tests/test_class_sh_trampoline_shared_from_this.py @@ -8,6 +8,7 @@ class PySft(m.Sft): pass +@pytest.mark.skip("WIP") def test_release_and_immediate_reclaim(): obj = PySft("PySft") assert obj.history == "PySft" @@ -27,6 +28,7 @@ def test_release_and_immediate_reclaim(): break # Comment out for manual leak checking (use `top` command). +@pytest.mark.skip("WIP") def test_release_to_cpp_stash(): obj = PySft("PySft") stash1 = m.SftSharedPtrStash(1) @@ -66,6 +68,7 @@ def test_release_to_cpp_stash(): assert stash1.use_count(0) == 1 +@pytest.mark.skip("WIP") def test_release_to_cpp_stash_leak(): obj = PySft("") while True: @@ -82,6 +85,7 @@ def test_release_to_cpp_stash_leak(): break # Comment out for manual leak checking (use `top` command). +@pytest.mark.skip("WIP") def test_release_to_cpp_stash_via_shared_from_this(): obj = PySft("PySft") stash1 = m.SftSharedPtrStash(1) @@ -94,6 +98,7 @@ def test_release_to_cpp_stash_via_shared_from_this(): assert stash1.use_count(1) == 3 +@pytest.mark.skip("WIP") def test_release_to_cpp_stash_via_shared_from_this_leak_1(): # WIP m.to_cout("") m.to_cout("") @@ -120,6 +125,7 @@ def test_release_to_cpp_stash_via_shared_from_this_leak_1(): # WIP break # Comment out for manual leak checking (use `top` command). +@pytest.mark.skip("WIP") def test_release_to_cpp_stash_via_shared_from_this_leak_2(): # WIP m.to_cout("") m.to_cout("AddSharedFromThis only")