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