Route default clear through renderer GL
This commit is contained in:
@@ -26,6 +26,7 @@ struct RecordedOpenGlStateCall {
|
||||
|
||||
std::vector<RecordedOpenGlStateCall> recorded_state_calls;
|
||||
std::vector<std::uint32_t> recorded_string_queries;
|
||||
std::vector<pp::renderer::gl::OpenGlDefaultClear> recorded_clear_calls;
|
||||
|
||||
void record_enable(std::uint32_t state) noexcept
|
||||
{
|
||||
@@ -78,6 +79,20 @@ const char* record_string_query(std::uint32_t name) noexcept
|
||||
}
|
||||
}
|
||||
|
||||
void record_clear_color(float r, float g, float b, float a) noexcept
|
||||
{
|
||||
recorded_clear_calls.push_back(pp::renderer::gl::OpenGlDefaultClear {
|
||||
.color = { r, g, b, a },
|
||||
});
|
||||
}
|
||||
|
||||
void record_clear(std::uint32_t mask) noexcept
|
||||
{
|
||||
recorded_clear_calls.push_back(pp::renderer::gl::OpenGlDefaultClear {
|
||||
.mask = mask,
|
||||
});
|
||||
}
|
||||
|
||||
void detects_common_extension_capabilities(pp::tests::Harness& h)
|
||||
{
|
||||
constexpr std::array<std::string_view, 2> extensions {
|
||||
@@ -785,6 +800,44 @@ void rejects_incomplete_app_runtime_info_dispatch(pp::tests::Harness& h)
|
||||
PP_EXPECT(h, result.status().code == pp::foundation::StatusCode::invalid_argument);
|
||||
}
|
||||
|
||||
void clears_app_default_target(pp::tests::Harness& h)
|
||||
{
|
||||
recorded_clear_calls.clear();
|
||||
|
||||
const auto clear = pp::renderer::gl::panopainter_default_clear();
|
||||
PP_EXPECT(h, clear.color[0] == 0.1F);
|
||||
PP_EXPECT(h, clear.color[1] == 0.1F);
|
||||
PP_EXPECT(h, clear.color[2] == 0.1F);
|
||||
PP_EXPECT(h, clear.color[3] == 1.0F);
|
||||
PP_EXPECT(h, clear.mask == 0x00004000U);
|
||||
|
||||
const auto status = pp::renderer::gl::clear_panopainter_default_target(
|
||||
pp::renderer::gl::OpenGlClearDispatch {
|
||||
.clear_color = record_clear_color,
|
||||
.clear = record_clear,
|
||||
});
|
||||
|
||||
PP_EXPECT(h, status.ok());
|
||||
PP_EXPECT(h, recorded_clear_calls.size() == 2U);
|
||||
PP_EXPECT(h, recorded_clear_calls[0].color[0] == 0.1F);
|
||||
PP_EXPECT(h, recorded_clear_calls[0].color[1] == 0.1F);
|
||||
PP_EXPECT(h, recorded_clear_calls[0].color[2] == 0.1F);
|
||||
PP_EXPECT(h, recorded_clear_calls[0].color[3] == 1.0F);
|
||||
PP_EXPECT(h, recorded_clear_calls[0].mask == 0U);
|
||||
PP_EXPECT(h, recorded_clear_calls[1].mask == 0x00004000U);
|
||||
}
|
||||
|
||||
void rejects_incomplete_app_clear_dispatch(pp::tests::Harness& h)
|
||||
{
|
||||
const auto status = pp::renderer::gl::clear_panopainter_default_target(
|
||||
pp::renderer::gl::OpenGlClearDispatch {
|
||||
.clear_color = record_clear_color,
|
||||
});
|
||||
|
||||
PP_EXPECT(h, !status.ok());
|
||||
PP_EXPECT(h, status.code == pp::foundation::StatusCode::invalid_argument);
|
||||
}
|
||||
|
||||
void maps_renderer_viewports_and_scissors(pp::tests::Harness& h)
|
||||
{
|
||||
const auto viewport = pp::renderer::gl::viewport_for_renderer_viewport(
|
||||
@@ -1163,6 +1216,8 @@ int main()
|
||||
harness.run("rejects_incomplete_app_initialization_state_dispatch", rejects_incomplete_app_initialization_state_dispatch);
|
||||
harness.run("queries_app_runtime_info", queries_app_runtime_info);
|
||||
harness.run("rejects_incomplete_app_runtime_info_dispatch", rejects_incomplete_app_runtime_info_dispatch);
|
||||
harness.run("clears_app_default_target", clears_app_default_target);
|
||||
harness.run("rejects_incomplete_app_clear_dispatch", rejects_incomplete_app_clear_dispatch);
|
||||
harness.run("maps_renderer_viewports_and_scissors", maps_renderer_viewports_and_scissors);
|
||||
harness.run("maps_renderer_blend_state_tokens", maps_renderer_blend_state_tokens);
|
||||
harness.run("maps_renderer_color_write_masks", maps_renderer_color_write_masks);
|
||||
|
||||
Reference in New Issue
Block a user