Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(3510)

Unified Diff: cc/quads/render_pass.cc

Issue 368403003: Use RenderPass to create DrawQuad in unittests (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@layerrawptrDQ
Patch Set: address review comments Created 6 years, 5 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « cc/quads/render_pass.h ('k') | cc/quads/render_pass_unittest.cc » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: cc/quads/render_pass.cc
diff --git a/cc/quads/render_pass.cc b/cc/quads/render_pass.cc
index 61fcb255f348a0186ed2fef5f60711f0d908fdf5..70161667ad23d2bfbb4105bdcf2f016195534a09 100644
--- a/cc/quads/render_pass.cc
+++ b/cc/quads/render_pass.cc
@@ -8,9 +8,19 @@
#include "cc/base/math_util.h"
#include "cc/debug/traced_value.h"
#include "cc/output/copy_output_request.h"
+#include "cc/quads/checkerboard_draw_quad.h"
+#include "cc/quads/debug_border_draw_quad.h"
#include "cc/quads/draw_quad.h"
+#include "cc/quads/io_surface_draw_quad.h"
+#include "cc/quads/picture_draw_quad.h"
#include "cc/quads/render_pass_draw_quad.h"
#include "cc/quads/shared_quad_state.h"
+#include "cc/quads/solid_color_draw_quad.h"
+#include "cc/quads/stream_video_draw_quad.h"
+#include "cc/quads/surface_draw_quad.h"
+#include "cc/quads/texture_draw_quad.h"
+#include "cc/quads/tile_draw_quad.h"
+#include "cc/quads/yuv_video_draw_quad.h"
namespace {
const size_t kDefaultNumSharedQuadStatesToReserve = 32;
@@ -174,4 +184,59 @@ SharedQuadState* RenderPass::CreateAndAppendSharedQuadState() {
return shared_quad_state_list.back();
}
+RenderPassDrawQuad* RenderPass::CopyFromAndAppendRenderPassDrawQuad(
+ const RenderPassDrawQuad* quad,
+ const SharedQuadState* shared_quad_state,
+ RenderPass::Id render_pass_id) {
+ RenderPassDrawQuad* copy_quad =
+ CopyFromAndAppendTypedDrawQuad<RenderPassDrawQuad>(quad);
+ copy_quad->shared_quad_state = shared_quad_state;
+ copy_quad->render_pass_id = render_pass_id;
+ return copy_quad;
+}
+
+DrawQuad* RenderPass::CopyFromAndAppendDrawQuad(
+ const DrawQuad* quad,
+ const SharedQuadState* shared_quad_state) {
+ switch (quad->material) {
+ case DrawQuad::CHECKERBOARD:
+ CopyFromAndAppendTypedDrawQuad<CheckerboardDrawQuad>(quad);
+ break;
+ case DrawQuad::DEBUG_BORDER:
+ CopyFromAndAppendTypedDrawQuad<DebugBorderDrawQuad>(quad);
+ break;
+ case DrawQuad::IO_SURFACE_CONTENT:
+ CopyFromAndAppendTypedDrawQuad<IOSurfaceDrawQuad>(quad);
+ break;
+ case DrawQuad::PICTURE_CONTENT:
+ CopyFromAndAppendTypedDrawQuad<PictureDrawQuad>(quad);
+ break;
+ case DrawQuad::TEXTURE_CONTENT:
+ CopyFromAndAppendTypedDrawQuad<TextureDrawQuad>(quad);
+ break;
+ case DrawQuad::SOLID_COLOR:
+ CopyFromAndAppendTypedDrawQuad<SolidColorDrawQuad>(quad);
+ break;
+ case DrawQuad::TILED_CONTENT:
+ CopyFromAndAppendTypedDrawQuad<TileDrawQuad>(quad);
+ break;
+ case DrawQuad::STREAM_VIDEO_CONTENT:
+ CopyFromAndAppendTypedDrawQuad<StreamVideoDrawQuad>(quad);
+ break;
+ case DrawQuad::SURFACE_CONTENT:
+ CopyFromAndAppendTypedDrawQuad<SurfaceDrawQuad>(quad);
+ break;
+ case DrawQuad::YUV_VIDEO_CONTENT:
+ CopyFromAndAppendTypedDrawQuad<YUVVideoDrawQuad>(quad);
+ break;
+ // RenderPass quads need to use specific CopyFrom function.
+ case DrawQuad::RENDER_PASS:
+ case DrawQuad::INVALID:
+ LOG(FATAL) << "Invalid DrawQuad material " << quad->material;
+ break;
+ }
+ quad_list.back()->shared_quad_state = shared_quad_state;
+ return quad_list.back();
+}
+
} // namespace cc
« no previous file with comments | « cc/quads/render_pass.h ('k') | cc/quads/render_pass_unittest.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698