From 474a696c5bc172de45405cf02ec2f9c917fb876c Mon Sep 17 00:00:00 2001 From: asuessenbach Date: Wed, 12 Jun 2024 17:29:36 +0200 Subject: [PATCH] Fix command sequence for enumerating commands with just one success code. --- VulkanHppGenerator.cpp | 20 +++++++++++++++++++- 1 file changed, 19 insertions(+), 1 deletion(-) diff --git a/VulkanHppGenerator.cpp b/VulkanHppGenerator.cpp index 9a26a6dd1..01f7b0f01 100644 --- a/VulkanHppGenerator.cpp +++ b/VulkanHppGenerator.cpp @@ -3282,13 +3282,31 @@ std::string VulkanHppGenerator::generateCallSequence( std::string const & switch ( commandData.successCodes.size() ) { case 1: + assert( commandData.successCodes[0] == "VK_SUCCESS" ); + if ( commandData.errorCodes.empty() ) { - assert( commandData.successCodes[0] == "VK_SUCCESS" ); std::string const callSequenceTemplate = R"(${dispatcher}${vkCommand}( ${firstCallArguments} ); ${resizes} ${dispatcher}${vkCommand}( ${secondCallArguments} ); )"; + return replaceWithMap( callSequenceTemplate, + { { "dispatcher", dispatcher }, + { "firstCallArguments", firstCallArguments }, + { "secondCallArguments", secondCallArguments }, + { "resizes", resizes }, + { "vkCommand", name } } ); + } + else + { + std::string const callSequenceTemplate = R"(VULKAN_HPP_NAMESPACE::Result result = ${dispatcher}${vkCommand}( ${firstCallArguments} ); + if ( result == VULKAN_HPP_NAMESPACE::Result::eSuccess ) + { + ${resizes} + result = ${dispatcher}${vkCommand}( ${secondCallArguments} ); + } +)"; + return replaceWithMap( callSequenceTemplate, { { "dispatcher", dispatcher }, { "firstCallArguments", firstCallArguments },