From 85c2ae4026fbbf29f6254778a622e599825a99b9 Mon Sep 17 00:00:00 2001 From: Ilya Doroshenko Date: Tue, 23 Jul 2024 15:43:55 +0200 Subject: [PATCH] added pool type traits, added special constructor for pool types --- snippets/SharedDestroy.hpp | 4 +++- snippets/SharedHandle.hpp | 35 ++++++++++++++++++++++++++++++++++- vulkan/vulkan.hpp | 2 +- vulkan/vulkan_shared.hpp | 37 ++++++++++++++++++++++++++++++++++++- 4 files changed, 74 insertions(+), 4 deletions(-) diff --git a/snippets/SharedDestroy.hpp b/snippets/SharedDestroy.hpp index dca61c722..50bbbccf0 100644 --- a/snippets/SharedDestroy.hpp +++ b/snippets/SharedDestroy.hpp @@ -116,6 +116,8 @@ class PoolFreeShared public: using DestructorType = typename SharedHandleTraits::DestructorType; + using PoolTypeExport = PoolType; + template using ReturnType = decltype( std::declval().free( PoolType(), 0u, nullptr, Dispatcher() ) ); @@ -135,7 +137,7 @@ class PoolFreeShared public: void destroy( DestructorType parent, HandleType handle ) const VULKAN_HPP_NOEXCEPT { - if( m_destroy && m_dispatch && m_pool ) + if ( m_destroy && m_dispatch && m_pool ) ( parent.*m_destroy )( m_pool.get(), 1u, &handle, *m_dispatch ); } diff --git a/snippets/SharedHandle.hpp b/snippets/SharedHandle.hpp index 336d0792b..339c99fa7 100644 --- a/snippets/SharedHandle.hpp +++ b/snippets/SharedHandle.hpp @@ -36,6 +36,28 @@ struct HasDestructor : std::integral_constant +struct HasPoolType : std::false_type +{ +}; + +template +struct HasPoolType::deleter::PoolTypeExport() )> : std::true_type +{ +}; + +template +struct GetPoolType +{ + using type = NoDestructor; +}; + +template +struct GetPoolType::value>::type> +{ + using type = typename SharedHandleTraits::deleter::PoolTypeExport; +}; + //===================================================================================================================== template @@ -241,12 +263,23 @@ class SharedHandle : public SharedHandleBase::value>::type> + template ::value && !HasPoolType::value>::type> explicit SharedHandle( HandleType handle, SharedHandle> parent, DeleterType deleter = DeleterType() ) VULKAN_HPP_NOEXCEPT : BaseType( handle, std::move( parent ), std::move( deleter ) ) { } + template ::value && HasPoolType::value>::type> + explicit SharedHandle( HandleType handle, + SharedHandle> parent, + SharedHandle::type> pool, + const Dispatcher & dispatch VULKAN_HPP_DEFAULT_DISPATCHER_ASSIGNMENT ) VULKAN_HPP_NOEXCEPT + : BaseType( handle, std::move( parent ), DeleterType{ std::move( pool ), dispatch } ) + { + } + template ::value>::type> explicit SharedHandle( HandleType handle, DeleterType deleter = DeleterType() ) VULKAN_HPP_NOEXCEPT : BaseType( handle, std::move( deleter ) ) { diff --git a/vulkan/vulkan.hpp b/vulkan/vulkan.hpp index 552cb6ebf..e596361fc 100644 --- a/vulkan/vulkan.hpp +++ b/vulkan/vulkan.hpp @@ -16851,7 +16851,7 @@ namespace VULKAN_HPP_NAMESPACE m_library = dlopen( "libvulkan.1.dylib", RTLD_NOW | RTLD_LOCAL ); } # elif defined( _WIN32 ) - m_library = ::LoadLibraryA( "vulkan-1.dll" ); + m_library = ::LoadLibraryA( "vulkan-1.dll" ); # else # error unsupported platform # endif diff --git a/vulkan/vulkan_shared.hpp b/vulkan/vulkan_shared.hpp index b39a39e87..69c28cc82 100644 --- a/vulkan/vulkan_shared.hpp +++ b/vulkan/vulkan_shared.hpp @@ -52,6 +52,28 @@ namespace VULKAN_HPP_NAMESPACE { }; + template + struct HasPoolType : std::false_type + { + }; + + template + struct HasPoolType::deleter::PoolTypeExport() )> : std::true_type + { + }; + + template + struct GetPoolType + { + using type = NoDestructor; + }; + + template + struct GetPoolType::value>::type> + { + using type = typename SharedHandleTraits::deleter::PoolTypeExport; + }; + //===================================================================================================================== template @@ -257,12 +279,23 @@ namespace VULKAN_HPP_NAMESPACE public: SharedHandle() = default; - template ::value>::type> + template ::value && !HasPoolType::value>::type> explicit SharedHandle( HandleType handle, SharedHandle> parent, DeleterType deleter = DeleterType() ) VULKAN_HPP_NOEXCEPT : BaseType( handle, std::move( parent ), std::move( deleter ) ) { } + template ::value && HasPoolType::value>::type> + explicit SharedHandle( HandleType handle, + SharedHandle> parent, + SharedHandle::type> pool, + const Dispatcher & dispatch VULKAN_HPP_DEFAULT_DISPATCHER_ASSIGNMENT ) VULKAN_HPP_NOEXCEPT + : BaseType( handle, std::move( parent ), DeleterType{ std::move( pool ), dispatch } ) + { + } + template ::value>::type> explicit SharedHandle( HandleType handle, DeleterType deleter = DeleterType() ) VULKAN_HPP_NOEXCEPT : BaseType( handle, std::move( deleter ) ) { @@ -390,6 +423,8 @@ namespace VULKAN_HPP_NAMESPACE public: using DestructorType = typename SharedHandleTraits::DestructorType; + using PoolTypeExport = PoolType; + template using ReturnType = decltype( std::declval().free( PoolType(), 0u, nullptr, Dispatcher() ) );