fixed a bug that Init after error position.

This commit is contained in:
HuYingzhuo(hugo/hyzboy) 2023-02-17 12:10:14 +08:00
parent 532421fea7
commit d2568072c7

View File

@ -326,7 +326,6 @@ extern "C"
uint32_t *spv_data;
uint32_t spv_length;
uint32_t shader_stage;
ShaderStageData input,output;
ShaderResourceData resource[VK_DESCRIPTOR_TYPE_COUNT];
@ -338,18 +337,6 @@ extern "C"
memset(this,0,sizeof(SPVData));
}
void Clear()
{
for(uint32_t i=0;i<VK_DESCRIPTOR_TYPE_COUNT;i++)
delete[] resource[i].items;
delete[] push_constant.items;
delete[] subpass_input.items;
delete[] input.items;
delete[] output.items;
}
public:
SPVData(const char *l,const char *dl)
@ -370,6 +357,8 @@ extern "C"
SPVData(const std::vector<uint32_t> &spirv)
{
Init();
result=true;
log=nullptr;
@ -379,13 +368,18 @@ extern "C"
spv_data=new uint32_t[spv_length];
spv_length*=sizeof(uint32_t);
memcpy(spv_data,spirv.data(),spv_length);
Init();
}
~SPVData()
{
Clear();
for(uint32_t i=0;i<VK_DESCRIPTOR_TYPE_COUNT;i++)
delete[] resource[i].items;
delete[] push_constant.items;
delete[] subpass_input.items;
delete[] input.items;
delete[] output.items;
delete[] log;
delete[] debug_log;
@ -559,8 +553,6 @@ extern "C"
SPVData *spv=new SPVData(spirv);
spv->shader_stage = shader_stage;
{
ShaderParse sp(spirv.data(),(uint32_t)spirv.size()*sizeof(uint32_t));