mirror of
https://github.com/KhronosGroup/Vulkan-Hpp.git
synced 2024-10-14 16:32:17 +00:00
Merge pull request #1432 from asuessenbach/funcs
Add support for functions getting a structure chain and having more than one success codes.
This commit is contained in:
commit
ec9ee4ff04
@ -3245,7 +3245,19 @@ std::string VulkanHppGenerator::generateCommandResultMultiSuccessWithErrors1Retu
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else if ( !isStructureChainAnchor( commandData.params[returnParam].type.type ) )
|
else if ( isStructureChainAnchor( commandData.params[returnParam].type.type ) )
|
||||||
|
{
|
||||||
|
std::map<size_t, VectorParamData> vectorParams = determineVectorParams( commandData.params );
|
||||||
|
if ( vectorParams.empty() )
|
||||||
|
{
|
||||||
|
return generateCommandSetStandardEnhancedChained(
|
||||||
|
definition,
|
||||||
|
generateCommandStandard( name, commandData, initialSkipCount, definition ),
|
||||||
|
generateCommandEnhanced( name, commandData, initialSkipCount, definition, vectorParams, { returnParam }, false, false, false, false ),
|
||||||
|
generateCommandEnhanced( name, commandData, initialSkipCount, definition, vectorParams, { returnParam }, false, false, true, false ) );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
{
|
{
|
||||||
std::map<size_t, VectorParamData> vectorParams = determineVectorParams( commandData.params );
|
std::map<size_t, VectorParamData> vectorParams = determineVectorParams( commandData.params );
|
||||||
if ( vectorParams.empty() )
|
if ( vectorParams.empty() )
|
||||||
@ -6817,12 +6829,16 @@ std::string VulkanHppGenerator::generateRAIIHandleCommandResultMultiSuccessWithE
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else if ( !isStructureChainAnchor( commandIt->second.params[returnParam].type.type ) )
|
else
|
||||||
{
|
{
|
||||||
std::map<size_t, VectorParamData> vectorParams = determineVectorParams( commandIt->second.params );
|
std::map<size_t, VectorParamData> vectorParams = determineVectorParams( commandIt->second.params );
|
||||||
if ( vectorParams.empty() )
|
if ( vectorParams.empty() )
|
||||||
{
|
{
|
||||||
str = generateRAIIHandleCommandEnhanced( commandIt, initialSkipCount, { returnParam }, vectorParams, definition, false, false );
|
str = generateRAIIHandleCommandEnhanced( commandIt, initialSkipCount, { returnParam }, vectorParams, definition, false, false );
|
||||||
|
if ( isStructureChainAnchor( commandIt->second.params[returnParam].type.type ) )
|
||||||
|
{
|
||||||
|
str += generateRAIIHandleCommandEnhanced( commandIt, initialSkipCount, { returnParam }, vectorParams, definition, true, false );
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return str;
|
return str;
|
||||||
@ -8660,8 +8676,8 @@ std::string VulkanHppGenerator::generateReturnType( CommandData const &
|
|||||||
{
|
{
|
||||||
assert( !unique );
|
assert( !unique );
|
||||||
modifiedDataType = dataType.starts_with( "std::vector" )
|
modifiedDataType = dataType.starts_with( "std::vector" )
|
||||||
? ( std::string( "std::vector<StructureChain" ) + ( raii ? "" : ", StructureChainAllocator" ) + "> " )
|
? ( std::string( "std::vector<StructureChain" ) + ( raii ? "" : ", StructureChainAllocator" ) + ">" )
|
||||||
: " StructureChain<X, Y, Z...> ";
|
: "StructureChain<X, Y, Z...>";
|
||||||
}
|
}
|
||||||
else if ( unique )
|
else if ( unique )
|
||||||
{
|
{
|
||||||
@ -8703,8 +8719,7 @@ std::string VulkanHppGenerator::generateReturnType( CommandData const &
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
else if ( ( commandData.returnType == "void" ) ||
|
else if ( ( commandData.returnType == "void" ) ||
|
||||||
( ( commandData.returnType == "VkResult" ) && ( commandData.successCodes.size() == 1 ) && ( commandData.errorCodes.empty() || raii ) ) ||
|
( ( commandData.returnType == "VkResult" ) && ( commandData.successCodes.size() == 1 ) && ( commandData.errorCodes.empty() || raii ) ) )
|
||||||
( chained && raii ) )
|
|
||||||
{
|
{
|
||||||
assert( !unique );
|
assert( !unique );
|
||||||
assert( ( commandData.returnType != "void" ) || ( returnParams.size() <= 2 ) );
|
assert( ( commandData.returnType != "void" ) || ( returnParams.size() <= 2 ) );
|
||||||
@ -8716,7 +8731,7 @@ std::string VulkanHppGenerator::generateReturnType( CommandData const &
|
|||||||
assert( !commandData.successCodes.empty() && ( commandData.successCodes[0] == "VK_SUCCESS" ) );
|
assert( !commandData.successCodes.empty() && ( commandData.successCodes[0] == "VK_SUCCESS" ) );
|
||||||
if ( ( 1 < commandData.successCodes.size() ) && ( ( returnParams.size() == 1 ) || ( ( returnParams.size() == 2 ) && vectorParams.empty() ) ) )
|
if ( ( 1 < commandData.successCodes.size() ) && ( ( returnParams.size() == 1 ) || ( ( returnParams.size() == 2 ) && vectorParams.empty() ) ) )
|
||||||
{
|
{
|
||||||
assert( !commandData.errorCodes.empty() && !chained );
|
assert( !commandData.errorCodes.empty() );
|
||||||
returnType = ( raii ? "std::pair<VULKAN_HPP_NAMESPACE::Result, " : "ResultValue<" ) + modifiedDataType + ">";
|
returnType = ( raii ? "std::pair<VULKAN_HPP_NAMESPACE::Result, " : "ResultValue<" ) + modifiedDataType + ">";
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
|
Loading…
Reference in New Issue
Block a user