-
-PipelineState::BoundTexture::BoundTexture(unsigned b):
- binding(b),
- changed(false),
- texture(0),
- sampler(0)
-{ }
-
-
-PipelineState::BoundUniformBlock::BoundUniformBlock(int b):
- binding(b),
- changed(false),
- block(0)
-{ }
+void PipelineState::check_bound_resources() const
+{
+ if(!shprog)
+ return;
+
+ for(const ReflectData::UniformBlockInfo &b: shprog->get_uniform_blocks())
+ if(b.bind_point!=ReflectData::DEFAULT_BLOCK)
+ {
+ auto i = lower_bound_member(resources, b.bind_point, &PipelineState::BoundResource::binding);
+ if(i==resources.end() || i->binding!=b.bind_point)
+ IO::print(IO::cerr, "Warning: No resource present for uniform block binding %d:%d (%s)\n", b.bind_point>>20, b.bind_point&0xFFFFF, b.name);
+ }
+
+ for(const ReflectData::UniformInfo &u: shprog->get_uniforms())
+ if(u.binding>=0 && is_image(u.type))
+ {
+ auto i = lower_bound_member(resources, u.binding, &PipelineState::BoundResource::binding);
+ if(i==resources.end() || i->binding!=u.binding)
+ IO::print(IO::cerr, "Warning: No resource present for texture binding %d:%d (%s)\n", u.binding>>20, u.binding&0xFFFFF, u.name);
+ }
+}