Index: cc/quads/draw_quad_unittest.cc |
diff --git a/cc/quads/draw_quad_unittest.cc b/cc/quads/draw_quad_unittest.cc |
index f0f77190ffbe7c2d5f07d4b93aaf53f2baf4aa7f..bf61b4b701a186a446a94f7c8c227af923923cdf 100644 |
--- a/cc/quads/draw_quad_unittest.cc |
+++ b/cc/quads/draw_quad_unittest.cc |
@@ -14,6 +14,7 @@ |
#include "cc/quads/debug_border_draw_quad.h" |
#include "cc/quads/io_surface_draw_quad.h" |
#include "cc/quads/picture_draw_quad.h" |
+#include "cc/quads/render_pass.h" |
#include "cc/quads/render_pass_draw_quad.h" |
#include "cc/quads/solid_color_draw_quad.h" |
#include "cc/quads/stream_video_draw_quad.h" |
@@ -60,7 +61,7 @@ TEST(DrawQuadTest, CopySharedQuadState) { |
EXPECT_EQ(blend_mode, copy->blend_mode); |
} |
-scoped_ptr<SharedQuadState> CreateSharedQuadState() { |
+SharedQuadState* CreateSharedQuadState(RenderPass* render_pass) { |
gfx::Transform quad_transform = gfx::Transform(1.0, 0.0, 0.5, 1.0, 0.5, 0.0); |
gfx::Size content_bounds(26, 28); |
gfx::Rect visible_content_rect(10, 12, 14, 16); |
@@ -70,7 +71,7 @@ scoped_ptr<SharedQuadState> CreateSharedQuadState() { |
int sorting_context_id = 65536; |
SkXfermode::Mode blend_mode = SkXfermode::kSrcOver_Mode; |
- scoped_ptr<SharedQuadState> state(new SharedQuadState); |
+ SharedQuadState* state = render_pass->CreateAndAppendSharedQuadState(); |
state->SetAll(quad_transform, |
content_bounds, |
visible_content_rect, |
@@ -79,7 +80,7 @@ scoped_ptr<SharedQuadState> CreateSharedQuadState() { |
opacity, |
blend_mode, |
sorting_context_id); |
- return state.Pass(); |
+ return state; |
} |
void CompareDrawQuad(DrawQuad* quad, |
@@ -93,10 +94,12 @@ void CompareDrawQuad(DrawQuad* quad, |
EXPECT_EQ(copy_shared_state, copy->shared_quad_state); |
} |
-#define CREATE_SHARED_STATE() \ |
- scoped_ptr<SharedQuadState> shared_state(CreateSharedQuadState()); \ |
- scoped_ptr<SharedQuadState> copy_shared_state(new SharedQuadState); \ |
- copy_shared_state->CopyFrom(shared_state.get()); |
+#define CREATE_SHARED_STATE() \ |
+ scoped_ptr<RenderPass> render_pass = RenderPass::Create(); \ |
+ SharedQuadState* shared_state(CreateSharedQuadState(render_pass.get())); \ |
+ SharedQuadState* copy_shared_state = \ |
+ render_pass->CreateAndAppendSharedQuadState(); \ |
+ copy_shared_state->CopyFrom(shared_state); |
#define QUAD_DATA \ |
gfx::Rect quad_rect(30, 40, 50, 60); \ |
@@ -104,235 +107,298 @@ void CompareDrawQuad(DrawQuad* quad, |
gfx::Rect ALLOW_UNUSED quad_opaque_rect(60, 55, 10, 10); \ |
bool ALLOW_UNUSED needs_blending = true; |
-#define SETUP_AND_COPY_QUAD_NEW(Type, quad) \ |
- scoped_ptr<DrawQuad> copy_new(quad_new->Copy(copy_shared_state.get())); \ |
- CompareDrawQuad(quad_new.get(), copy_new.get(), copy_shared_state.get()); \ |
- const Type* ALLOW_UNUSED copy_quad = Type::MaterialCast(copy_new.get()); |
- |
-#define SETUP_AND_COPY_QUAD_ALL(Type, quad) \ |
- scoped_ptr<DrawQuad> copy_all(quad_all->Copy(copy_shared_state.get())); \ |
- CompareDrawQuad(quad_all.get(), copy_all.get(), copy_shared_state.get()); \ |
- copy_quad = Type::MaterialCast(copy_all.get()); |
- |
-#define SETUP_AND_COPY_QUAD_NEW_1(Type, quad, a) \ |
- scoped_ptr<DrawQuad> copy_new(quad_new->Copy(copy_shared_state.get(), a)); \ |
- CompareDrawQuad(quad_new.get(), copy_new.get(), copy_shared_state.get()); \ |
- const Type* ALLOW_UNUSED copy_quad = Type::MaterialCast(copy_new.get()); |
- |
-#define SETUP_AND_COPY_QUAD_ALL_1(Type, quad, a) \ |
- scoped_ptr<DrawQuad> copy_all(quad_all->Copy(copy_shared_state.get(), a)); \ |
- CompareDrawQuad(quad_all.get(), copy_all.get(), copy_shared_state.get()); \ |
- copy_quad = Type::MaterialCast(copy_all.get()); |
- |
-#define CREATE_QUAD_1_NEW(Type, a) \ |
- scoped_ptr<Type> quad_new(Type::Create()); \ |
- { \ |
- QUAD_DATA \ |
- quad_new->SetNew(shared_state.get(), quad_rect, a); \ |
- } \ |
- SETUP_AND_COPY_QUAD_NEW(Type, quad_new); |
- |
-#define CREATE_QUAD_1_ALL(Type, a) \ |
- scoped_ptr<Type> quad_all(Type::Create()); \ |
- { \ |
- QUAD_DATA \ |
- quad_all->SetAll(shared_state.get(), quad_rect, quad_opaque_rect, \ |
- quad_visible_rect, needs_blending, a); \ |
- } \ |
- SETUP_AND_COPY_QUAD_ALL(Type, quad_all); |
- |
-#define CREATE_QUAD_2_NEW(Type, a, b) \ |
- scoped_ptr<Type> quad_new(Type::Create()); \ |
- { \ |
- QUAD_DATA \ |
- quad_new->SetNew(shared_state.get(), quad_rect, a, b); \ |
- } \ |
- SETUP_AND_COPY_QUAD_NEW(Type, quad_new); |
- |
-#define CREATE_QUAD_2_ALL(Type, a, b) \ |
- scoped_ptr<Type> quad_all(Type::Create()); \ |
- { \ |
- QUAD_DATA \ |
- quad_all->SetAll(shared_state.get(), quad_rect, quad_opaque_rect, \ |
- quad_visible_rect, needs_blending, a, b); \ |
- } \ |
- SETUP_AND_COPY_QUAD_ALL(Type, quad_all); |
- |
-#define CREATE_QUAD_3_NEW(Type, a, b, c) \ |
- scoped_ptr<Type> quad_new(Type::Create()); \ |
- { \ |
- QUAD_DATA \ |
- quad_new->SetNew(shared_state.get(), quad_rect, a, b, c); \ |
- } \ |
- SETUP_AND_COPY_QUAD_NEW(Type, quad_new); |
- |
-#define CREATE_QUAD_3_ALL(Type, a, b, c) \ |
- scoped_ptr<Type> quad_all(Type::Create()); \ |
- { \ |
- QUAD_DATA \ |
- quad_all->SetAll(shared_state.get(), quad_rect, quad_opaque_rect, \ |
- quad_visible_rect, needs_blending, a, b, c); \ |
- } \ |
- SETUP_AND_COPY_QUAD_ALL(Type, quad_all); |
- |
-#define CREATE_QUAD_4_NEW(Type, a, b, c, d) \ |
- scoped_ptr<Type> quad_new(Type::Create()); \ |
- { \ |
- QUAD_DATA \ |
- quad_new->SetNew(shared_state.get(), quad_rect, a, b, c, d); \ |
- } \ |
- SETUP_AND_COPY_QUAD_NEW(Type, quad_new); |
- |
-#define CREATE_QUAD_4_ALL(Type, a, b, c, d) \ |
- scoped_ptr<Type> quad_all(Type::Create()); \ |
- { \ |
- QUAD_DATA \ |
- quad_all->SetAll(shared_state.get(), quad_rect, quad_opaque_rect, \ |
- quad_visible_rect, needs_blending, a, b, c, d); \ |
- } \ |
- SETUP_AND_COPY_QUAD_ALL(Type, quad_all); |
- |
-#define CREATE_QUAD_5_NEW(Type, a, b, c, d, e) \ |
- scoped_ptr<Type> quad_new(Type::Create()); \ |
- { \ |
- QUAD_DATA \ |
- quad_new->SetNew(shared_state.get(), quad_rect, a, b, c, d, e); \ |
- } \ |
- SETUP_AND_COPY_QUAD_NEW(Type, quad_new); |
- |
-#define CREATE_QUAD_5_ALL(Type, a, b, c, d, e) \ |
- scoped_ptr<Type> quad_all(Type::Create()); \ |
- { \ |
- QUAD_DATA \ |
- quad_all->SetAll(shared_state.get(), quad_rect, quad_opaque_rect, \ |
- quad_visible_rect, needs_blending, a, b, c, d, e); \ |
- } \ |
- SETUP_AND_COPY_QUAD_ALL(Type, quad_all); |
- |
-#define CREATE_QUAD_5_NEW_1(Type, a, b, c, d, e, copy_a) \ |
- scoped_ptr<Type> quad_new(Type::Create()); \ |
- { \ |
- QUAD_DATA \ |
- quad_new->SetNew(shared_state.get(), quad_rect, a, b, c, d, e); \ |
- } \ |
- SETUP_AND_COPY_QUAD_NEW_1(Type, quad_new, copy_a); |
- |
-#define CREATE_QUAD_5_ALL_1(Type, a, b, c, d, e, copy_a) \ |
- scoped_ptr<Type> quad_all(Type::Create()); \ |
- { \ |
- QUAD_DATA \ |
- quad_all->SetAll(shared_state.get(), quad_rect, quad_opaque_rect, \ |
- quad_visible_rect, needs_blending, a, b, c, d, e); \ |
- } \ |
- SETUP_AND_COPY_QUAD_ALL_1(Type, quad_all, copy_a); |
- |
-#define CREATE_QUAD_6_NEW(Type, a, b, c, d, e, f) \ |
- scoped_ptr<Type> quad_new(Type::Create()); \ |
- { \ |
- QUAD_DATA \ |
- quad_new->SetNew(shared_state.get(), quad_rect, a, b, c, d, e, f); \ |
- } \ |
- SETUP_AND_COPY_QUAD_NEW(Type, quad_new); |
- |
-#define CREATE_QUAD_6_ALL(Type, a, b, c, d, e, f) \ |
- scoped_ptr<Type> quad_all(Type::Create()); \ |
- { \ |
- QUAD_DATA \ |
- quad_all->SetAll(shared_state.get(), quad_rect, quad_opaque_rect, \ |
- quad_visible_rect, needs_blending, a, b, c, d, e, f); \ |
- } \ |
- SETUP_AND_COPY_QUAD_ALL(Type, quad_all); |
- |
-#define CREATE_QUAD_7_NEW(Type, a, b, c, d, e, f, g) \ |
- scoped_ptr<Type> quad_new(Type::Create()); \ |
- { \ |
- QUAD_DATA \ |
- quad_new->SetNew(shared_state.get(), quad_rect, a, b, c, d, e, f, g); \ |
- } \ |
- SETUP_AND_COPY_QUAD_NEW(Type, quad_new); |
- |
-#define CREATE_QUAD_7_ALL(Type, a, b, c, d, e, f, g) \ |
- scoped_ptr<Type> quad_all(Type::Create()); \ |
- { \ |
- QUAD_DATA \ |
- quad_all->SetAll(shared_state.get(), quad_rect, quad_opaque_rect, \ |
- quad_visible_rect, needs_blending, \ |
- a, b, c, d, e, f, g); \ |
- } \ |
- SETUP_AND_COPY_QUAD_ALL(Type, quad_all); |
- |
-#define CREATE_QUAD_7_NEW_1(Type, a, b, c, d, e, f, g, copy_a) \ |
- scoped_ptr<Type> quad_new(Type::Create()); \ |
- { \ |
- QUAD_DATA \ |
- quad_new->SetNew(shared_state.get(), quad_rect, a, b, c, d, e, f, g); \ |
- } \ |
- SETUP_AND_COPY_QUAD_NEW_1(Type, quad_new, copy_a); |
- |
-#define CREATE_QUAD_7_ALL_1(Type, a, b, c, d, e, f, g, copy_a) \ |
- scoped_ptr<Type> quad_all(Type::Create()); \ |
- { \ |
- QUAD_DATA \ |
- quad_all->SetAll(shared_state.get(), quad_rect, quad_opaque_rect, \ |
- quad_visible_rect, needs_blending, \ |
- a, b, c, d, e, f, g); \ |
- } \ |
- SETUP_AND_COPY_QUAD_ALL_1(Type, quad_all, copy_a); |
- |
-#define CREATE_QUAD_8_NEW(Type, a, b, c, d, e, f, g, h) \ |
- scoped_ptr<Type> quad_new(Type::Create()); \ |
- { \ |
- QUAD_DATA \ |
- quad_new->SetNew(shared_state.get(), quad_rect, a, b, c, d, e, f, g, h); \ |
- } \ |
- SETUP_AND_COPY_QUAD_NEW(Type, quad_new); |
- |
-#define CREATE_QUAD_8_ALL(Type, a, b, c, d, e, f, g, h) \ |
- scoped_ptr<Type> quad_all(Type::Create()); \ |
- { \ |
- QUAD_DATA \ |
- quad_all->SetAll(shared_state.get(), quad_rect, quad_opaque_rect, \ |
- quad_visible_rect, needs_blending, \ |
- a, b, c, d, e, f, g, h); \ |
- } \ |
- SETUP_AND_COPY_QUAD_ALL(Type, quad_all); |
- |
-#define CREATE_QUAD_8_NEW_1(Type, a, b, c, d, e, f, g, h, copy_a) \ |
- scoped_ptr<Type> quad_new(Type::Create()); \ |
- { \ |
- QUAD_DATA \ |
- quad_new->SetNew(shared_state.get(), quad_rect, a, b, c, d, e, f, g, h); \ |
- } \ |
- SETUP_AND_COPY_QUAD_NEW_1(Type, quad_new, copy_a); |
- |
-#define CREATE_QUAD_8_ALL_1(Type, a, b, c, d, e, f, g, h, copy_a) \ |
- scoped_ptr<Type> quad_all(Type::Create()); \ |
- { \ |
- QUAD_DATA \ |
- quad_all->SetAll(shared_state.get(), quad_rect, quad_opaque_rect, \ |
- quad_visible_rect, needs_blending, \ |
- a, b, c, d, e, f, g, h); \ |
- } \ |
- SETUP_AND_COPY_QUAD_ALL_1(Type, quad_all, copy_a); |
- |
-#define CREATE_QUAD_9_NEW(Type, a, b, c, d, e, f, g, h, i) \ |
- scoped_ptr<Type> quad_new(Type::Create()); \ |
- { \ |
- QUAD_DATA \ |
- quad_new->SetNew(shared_state.get(), quad_rect, \ |
- a, b, c, d, e, f, g, h, i); \ |
- } \ |
- SETUP_AND_COPY_QUAD_NEW(Type, quad_new); |
+#define SETUP_AND_COPY_QUAD_NEW(Type, quad) \ |
+ DrawQuad* copy_new = \ |
+ render_pass->CopyFromAndAppendDrawQuad(quad_new, copy_shared_state); \ |
+ CompareDrawQuad(quad_new, copy_new, copy_shared_state); \ |
+ const Type* ALLOW_UNUSED copy_quad = Type::MaterialCast(copy_new); |
+ |
+#define SETUP_AND_COPY_QUAD_ALL(Type, quad) \ |
+ DrawQuad* copy_all = \ |
+ render_pass->CopyFromAndAppendDrawQuad(quad_all, copy_shared_state); \ |
+ CompareDrawQuad(quad_all, copy_all, copy_shared_state); \ |
+ copy_quad = Type::MaterialCast(copy_all); |
+ |
+#define SETUP_AND_COPY_QUAD_NEW_RP(Type, quad, a) \ |
+ DrawQuad* copy_new = render_pass->CopyFromAndAppendRenderPassDrawQuad( \ |
+ quad_new, copy_shared_state, a); \ |
+ CompareDrawQuad(quad_new, copy_new, copy_shared_state); \ |
+ const Type* ALLOW_UNUSED copy_quad = Type::MaterialCast(copy_new); |
+ |
+#define SETUP_AND_COPY_QUAD_ALL_RP(Type, quad, a) \ |
+ DrawQuad* copy_all = render_pass->CopyFromAndAppendRenderPassDrawQuad( \ |
+ quad_all, copy_shared_state, a); \ |
+ CompareDrawQuad(quad_all, copy_all, copy_shared_state); \ |
+ copy_quad = Type::MaterialCast(copy_all); |
+ |
+#define CREATE_QUAD_1_NEW(Type, a) \ |
+ Type* quad_new = render_pass->CreateAndAppendDrawQuad<Type>(); \ |
+ { QUAD_DATA quad_new->SetNew(shared_state, quad_rect, a); } \ |
+ SETUP_AND_COPY_QUAD_NEW(Type, quad_new); |
+ |
+#define CREATE_QUAD_1_ALL(Type, a) \ |
+ Type* quad_all = render_pass->CreateAndAppendDrawQuad<Type>(); \ |
+ { \ |
+ QUAD_DATA quad_all->SetAll(shared_state, \ |
+ quad_rect, \ |
+ quad_opaque_rect, \ |
+ quad_visible_rect, \ |
+ needs_blending, \ |
+ a); \ |
+ } \ |
+ SETUP_AND_COPY_QUAD_ALL(Type, quad_all); |
+ |
+#define CREATE_QUAD_2_NEW(Type, a, b) \ |
+ Type* quad_new = render_pass->CreateAndAppendDrawQuad<Type>(); \ |
+ { QUAD_DATA quad_new->SetNew(shared_state, quad_rect, a, b); } \ |
+ SETUP_AND_COPY_QUAD_NEW(Type, quad_new); |
+ |
+#define CREATE_QUAD_2_ALL(Type, a, b) \ |
+ Type* quad_all = render_pass->CreateAndAppendDrawQuad<Type>(); \ |
+ { \ |
+ QUAD_DATA quad_all->SetAll(shared_state, \ |
+ quad_rect, \ |
+ quad_opaque_rect, \ |
+ quad_visible_rect, \ |
+ needs_blending, \ |
+ a, \ |
+ b); \ |
+ } \ |
+ SETUP_AND_COPY_QUAD_ALL(Type, quad_all); |
+ |
+#define CREATE_QUAD_3_NEW(Type, a, b, c) \ |
+ Type* quad_new = render_pass->CreateAndAppendDrawQuad<Type>(); \ |
+ { QUAD_DATA quad_new->SetNew(shared_state, quad_rect, a, b, c); } \ |
+ SETUP_AND_COPY_QUAD_NEW(Type, quad_new); |
+ |
+#define CREATE_QUAD_3_ALL(Type, a, b, c) \ |
+ Type* quad_all = render_pass->CreateAndAppendDrawQuad<Type>(); \ |
+ { \ |
+ QUAD_DATA quad_all->SetAll(shared_state, \ |
+ quad_rect, \ |
+ quad_opaque_rect, \ |
+ quad_visible_rect, \ |
+ needs_blending, \ |
+ a, \ |
+ b, \ |
+ c); \ |
+ } \ |
+ SETUP_AND_COPY_QUAD_ALL(Type, quad_all); |
+ |
+#define CREATE_QUAD_4_NEW(Type, a, b, c, d) \ |
+ Type* quad_new = render_pass->CreateAndAppendDrawQuad<Type>(); \ |
+ { QUAD_DATA quad_new->SetNew(shared_state, quad_rect, a, b, c, d); } \ |
+ SETUP_AND_COPY_QUAD_NEW(Type, quad_new); |
+ |
+#define CREATE_QUAD_4_ALL(Type, a, b, c, d) \ |
+ Type* quad_all = render_pass->CreateAndAppendDrawQuad<Type>(); \ |
+ { \ |
+ QUAD_DATA quad_all->SetAll(shared_state, \ |
+ quad_rect, \ |
+ quad_opaque_rect, \ |
+ quad_visible_rect, \ |
+ needs_blending, \ |
+ a, \ |
+ b, \ |
+ c, \ |
+ d); \ |
+ } \ |
+ SETUP_AND_COPY_QUAD_ALL(Type, quad_all); |
+ |
+#define CREATE_QUAD_5_NEW(Type, a, b, c, d, e) \ |
+ Type* quad_new = render_pass->CreateAndAppendDrawQuad<Type>(); \ |
+ { QUAD_DATA quad_new->SetNew(shared_state, quad_rect, a, b, c, d, e); } \ |
+ SETUP_AND_COPY_QUAD_NEW(Type, quad_new); |
+ |
+#define CREATE_QUAD_5_ALL(Type, a, b, c, d, e) \ |
+ Type* quad_all = render_pass->CreateAndAppendDrawQuad<Type>(); \ |
+ { \ |
+ QUAD_DATA quad_all->SetAll(shared_state, \ |
+ quad_rect, \ |
+ quad_opaque_rect, \ |
+ quad_visible_rect, \ |
+ needs_blending, \ |
+ a, \ |
+ b, \ |
+ c, \ |
+ d, \ |
+ e); \ |
+ } \ |
+ SETUP_AND_COPY_QUAD_ALL(Type, quad_all); |
+ |
+#define CREATE_QUAD_5_NEW_RP(Type, a, b, c, d, e, copy_a) \ |
+ Type* quad_new = render_pass->CreateAndAppendDrawQuad<Type>(); \ |
+ { QUAD_DATA quad_new->SetNew(shared_state, quad_rect, a, b, c, d, e); } \ |
+ SETUP_AND_COPY_QUAD_NEW_RP(Type, quad_new, copy_a); |
+ |
+#define CREATE_QUAD_5_ALL_RP(Type, a, b, c, d, e, copy_a) \ |
+ Type* quad_all = render_pass->CreateAndAppendDrawQuad<Type>(); \ |
+ { \ |
+ QUAD_DATA quad_all->SetAll(shared_state, \ |
+ quad_rect, \ |
+ quad_opaque_rect, \ |
+ quad_visible_rect, \ |
+ needs_blending, \ |
+ a, \ |
+ b, \ |
+ c, \ |
+ d, \ |
+ e); \ |
+ } \ |
+ SETUP_AND_COPY_QUAD_ALL_RP(Type, quad_all, copy_a); |
+ |
+#define CREATE_QUAD_6_NEW(Type, a, b, c, d, e, f) \ |
+ Type* quad_new = render_pass->CreateAndAppendDrawQuad<Type>(); \ |
+ { QUAD_DATA quad_new->SetNew(shared_state, quad_rect, a, b, c, d, e, f); } \ |
+ SETUP_AND_COPY_QUAD_NEW(Type, quad_new); |
+ |
+#define CREATE_QUAD_6_ALL(Type, a, b, c, d, e, f) \ |
+ Type* quad_all = render_pass->CreateAndAppendDrawQuad<Type>(); \ |
+ { \ |
+ QUAD_DATA quad_all->SetAll(shared_state, \ |
+ quad_rect, \ |
+ quad_opaque_rect, \ |
+ quad_visible_rect, \ |
+ needs_blending, \ |
+ a, \ |
+ b, \ |
+ c, \ |
+ d, \ |
+ e, \ |
+ f); \ |
+ } \ |
+ SETUP_AND_COPY_QUAD_ALL(Type, quad_all); |
+ |
+#define CREATE_QUAD_7_NEW(Type, a, b, c, d, e, f, g) \ |
+ Type* quad_new = render_pass->CreateAndAppendDrawQuad<Type>(); \ |
+ { \ |
+ QUAD_DATA quad_new->SetNew(shared_state, quad_rect, a, b, c, d, e, f, g); \ |
+ } \ |
+ SETUP_AND_COPY_QUAD_NEW(Type, quad_new); |
+ |
+#define CREATE_QUAD_7_ALL(Type, a, b, c, d, e, f, g) \ |
+ Type* quad_all = render_pass->CreateAndAppendDrawQuad<Type>(); \ |
+ { \ |
+ QUAD_DATA quad_all->SetAll(shared_state, \ |
+ quad_rect, \ |
+ quad_opaque_rect, \ |
+ quad_visible_rect, \ |
+ needs_blending, \ |
+ a, \ |
+ b, \ |
+ c, \ |
+ d, \ |
+ e, \ |
+ f, \ |
+ g); \ |
+ } \ |
+ SETUP_AND_COPY_QUAD_ALL(Type, quad_all); |
+ |
+#define CREATE_QUAD_7_NEW_RP(Type, a, b, c, d, e, f, g, copy_a) \ |
+ Type* quad_new = render_pass->CreateAndAppendDrawQuad<Type>(); \ |
+ { \ |
+ QUAD_DATA quad_new->SetNew(shared_state, quad_rect, a, b, c, d, e, f, g); \ |
+ } \ |
+ SETUP_AND_COPY_QUAD_NEW_RP(Type, quad_new, copy_a); |
+ |
+#define CREATE_QUAD_7_ALL_RP(Type, a, b, c, d, e, f, g, copy_a) \ |
+ Type* quad_all = render_pass->CreateAndAppendDrawQuad<Type>(); \ |
+ { \ |
+ QUAD_DATA quad_all->SetAll(shared_state, \ |
+ quad_rect, \ |
+ quad_opaque_rect, \ |
+ quad_visible_rect, \ |
+ needs_blending, \ |
+ a, \ |
+ b, \ |
+ c, \ |
+ d, \ |
+ e, \ |
+ f, \ |
+ g); \ |
+ } \ |
+ SETUP_AND_COPY_QUAD_ALL_RP(Type, quad_all, copy_a); |
+ |
+#define CREATE_QUAD_8_NEW(Type, a, b, c, d, e, f, g, h) \ |
+ Type* quad_new = render_pass->CreateAndAppendDrawQuad<Type>(); \ |
+ { \ |
+ QUAD_DATA quad_new->SetNew( \ |
+ shared_state, quad_rect, a, b, c, d, e, f, g, h); \ |
+ } \ |
+ SETUP_AND_COPY_QUAD_NEW(Type, quad_new); |
+ |
+#define CREATE_QUAD_8_ALL(Type, a, b, c, d, e, f, g, h) \ |
+ Type* quad_all = render_pass->CreateAndAppendDrawQuad<Type>(); \ |
+ { \ |
+ QUAD_DATA quad_all->SetAll(shared_state, \ |
+ quad_rect, \ |
+ quad_opaque_rect, \ |
+ quad_visible_rect, \ |
+ needs_blending, \ |
+ a, \ |
+ b, \ |
+ c, \ |
+ d, \ |
+ e, \ |
+ f, \ |
+ g, \ |
+ h); \ |
+ } \ |
+ SETUP_AND_COPY_QUAD_ALL(Type, quad_all); |
+ |
+#define CREATE_QUAD_8_NEW_RP(Type, a, b, c, d, e, f, g, h, copy_a) \ |
+ Type* quad_new = render_pass->CreateAndAppendDrawQuad<Type>(); \ |
+ { \ |
+ QUAD_DATA quad_new->SetNew( \ |
+ shared_state, quad_rect, a, b, c, d, e, f, g, h); \ |
+ } \ |
+ SETUP_AND_COPY_QUAD_NEW_RP(Type, quad_new, copy_a); |
+ |
+#define CREATE_QUAD_8_ALL_RP(Type, a, b, c, d, e, f, g, h, copy_a) \ |
+ Type* quad_all = render_pass->CreateAndAppendDrawQuad<Type>(); \ |
+ { \ |
+ QUAD_DATA quad_all->SetAll(shared_state, \ |
+ quad_rect, \ |
+ quad_opaque_rect, \ |
+ quad_visible_rect, \ |
+ needs_blending, \ |
+ a, \ |
+ b, \ |
+ c, \ |
+ d, \ |
+ e, \ |
+ f, \ |
+ g, \ |
+ h); \ |
+ } \ |
+ SETUP_AND_COPY_QUAD_ALL_RP(Type, quad_all, copy_a); |
+ |
+#define CREATE_QUAD_9_NEW(Type, a, b, c, d, e, f, g, h, i) \ |
+ Type* quad_new = render_pass->CreateAndAppendDrawQuad<Type>(); \ |
+ { \ |
+ QUAD_DATA quad_new->SetNew( \ |
+ shared_state, quad_rect, a, b, c, d, e, f, g, h, i); \ |
+ } \ |
+ SETUP_AND_COPY_QUAD_NEW(Type, quad_new); |
#define CREATE_QUAD_9_ALL(Type, a, b, c, d, e, f, g, h, i) \ |
- scoped_ptr<Type> quad_all(Type::Create()); \ |
- { \ |
- QUAD_DATA \ |
- quad_all->SetAll(shared_state.get(), quad_rect, quad_opaque_rect, \ |
- quad_visible_rect, needs_blending, \ |
- a, b, c, d, e, f, g, h, i); \ |
- } \ |
- SETUP_AND_COPY_QUAD_ALL(Type, quad_all); |
+ { \ |
+ QUAD_DATA quad_all->SetAll(shared_state, \ |
+ quad_rect, \ |
+ quad_opaque_rect, \ |
+ quad_visible_rect, \ |
+ needs_blending, \ |
+ a, \ |
+ b, \ |
+ c, \ |
+ d, \ |
+ e, \ |
+ f, \ |
+ g, \ |
+ h, \ |
+ i); \ |
+ } \ |
+ SETUP_AND_COPY_QUAD_ALL(Type, quad_all); |
TEST(DrawQuadTest, CopyCheckerboardDrawQuad) { |
gfx::Rect visible_rect(40, 50, 30, 20); |
@@ -411,16 +477,16 @@ TEST(DrawQuadTest, CopyRenderPassDrawQuad) { |
RenderPass::Id copied_render_pass_id(235, 11); |
CREATE_SHARED_STATE(); |
- CREATE_QUAD_8_NEW_1(RenderPassDrawQuad, |
- visible_rect, |
- render_pass_id, |
- is_replica, |
- mask_resource_id, |
- contents_changed_since_last_frame, |
- mask_u_v_rect, |
- filters, |
- background_filters, |
- copied_render_pass_id); |
+ CREATE_QUAD_8_NEW_RP(RenderPassDrawQuad, |
+ visible_rect, |
+ render_pass_id, |
+ is_replica, |
+ mask_resource_id, |
+ contents_changed_since_last_frame, |
+ mask_u_v_rect, |
+ filters, |
+ background_filters, |
+ copied_render_pass_id); |
EXPECT_EQ(DrawQuad::RENDER_PASS, copy_quad->material); |
EXPECT_RECT_EQ(visible_rect, copy_quad->visible_rect); |
EXPECT_EQ(copied_render_pass_id, copy_quad->render_pass_id); |
@@ -432,15 +498,15 @@ TEST(DrawQuadTest, CopyRenderPassDrawQuad) { |
EXPECT_EQ(filters, copy_quad->filters); |
EXPECT_EQ(background_filters, copy_quad->background_filters); |
- CREATE_QUAD_7_ALL_1(RenderPassDrawQuad, |
- render_pass_id, |
- is_replica, |
- mask_resource_id, |
- contents_changed_since_last_frame, |
- mask_u_v_rect, |
- filters, |
- background_filters, |
- copied_render_pass_id); |
+ CREATE_QUAD_7_ALL_RP(RenderPassDrawQuad, |
+ render_pass_id, |
+ is_replica, |
+ mask_resource_id, |
+ contents_changed_since_last_frame, |
+ mask_u_v_rect, |
+ filters, |
+ background_filters, |
+ copied_render_pass_id); |
EXPECT_EQ(DrawQuad::RENDER_PASS, copy_quad->material); |
EXPECT_EQ(copied_render_pass_id, copy_quad->render_pass_id); |
EXPECT_EQ(is_replica, copy_quad->is_replica); |
@@ -709,7 +775,7 @@ TEST_F(DrawQuadIteratorTest, CheckerboardDrawQuad) { |
CREATE_SHARED_STATE(); |
CREATE_QUAD_2_NEW(CheckerboardDrawQuad, visible_rect, color); |
- EXPECT_EQ(0, IterateAndCount(quad_new.get())); |
+ EXPECT_EQ(0, IterateAndCount(quad_new)); |
} |
TEST_F(DrawQuadIteratorTest, DebugBorderDrawQuad) { |
@@ -719,7 +785,7 @@ TEST_F(DrawQuadIteratorTest, DebugBorderDrawQuad) { |
CREATE_SHARED_STATE(); |
CREATE_QUAD_3_NEW(DebugBorderDrawQuad, visible_rect, color, width); |
- EXPECT_EQ(0, IterateAndCount(quad_new.get())); |
+ EXPECT_EQ(0, IterateAndCount(quad_new)); |
} |
TEST_F(DrawQuadIteratorTest, IOSurfaceDrawQuad) { |
@@ -737,7 +803,7 @@ TEST_F(DrawQuadIteratorTest, IOSurfaceDrawQuad) { |
resource_id, |
orientation); |
EXPECT_EQ(resource_id, quad_new->io_surface_resource_id); |
- EXPECT_EQ(1, IterateAndCount(quad_new.get())); |
+ EXPECT_EQ(1, IterateAndCount(quad_new)); |
EXPECT_EQ(resource_id + 1, quad_new->io_surface_resource_id); |
} |
@@ -757,21 +823,21 @@ TEST_F(DrawQuadIteratorTest, RenderPassDrawQuad) { |
RenderPass::Id copied_render_pass_id(235, 11); |
CREATE_SHARED_STATE(); |
- CREATE_QUAD_8_NEW_1(RenderPassDrawQuad, |
- visible_rect, |
- render_pass_id, |
- is_replica, |
- mask_resource_id, |
- contents_changed_since_last_frame, |
- mask_u_v_rect, |
- filters, |
- background_filters, |
- copied_render_pass_id); |
+ CREATE_QUAD_8_NEW_RP(RenderPassDrawQuad, |
+ visible_rect, |
+ render_pass_id, |
+ is_replica, |
+ mask_resource_id, |
+ contents_changed_since_last_frame, |
+ mask_u_v_rect, |
+ filters, |
+ background_filters, |
+ copied_render_pass_id); |
EXPECT_EQ(mask_resource_id, quad_new->mask_resource_id); |
- EXPECT_EQ(1, IterateAndCount(quad_new.get())); |
+ EXPECT_EQ(1, IterateAndCount(quad_new)); |
EXPECT_EQ(mask_resource_id + 1, quad_new->mask_resource_id); |
quad_new->mask_resource_id = 0; |
- EXPECT_EQ(0, IterateAndCount(quad_new.get())); |
+ EXPECT_EQ(0, IterateAndCount(quad_new)); |
EXPECT_EQ(0u, quad_new->mask_resource_id); |
} |
@@ -783,7 +849,7 @@ TEST_F(DrawQuadIteratorTest, SolidColorDrawQuad) { |
CREATE_SHARED_STATE(); |
CREATE_QUAD_3_NEW( |
SolidColorDrawQuad, visible_rect, color, force_anti_aliasing_off); |
- EXPECT_EQ(0, IterateAndCount(quad_new.get())); |
+ EXPECT_EQ(0, IterateAndCount(quad_new)); |
} |
TEST_F(DrawQuadIteratorTest, StreamVideoDrawQuad) { |
@@ -796,7 +862,7 @@ TEST_F(DrawQuadIteratorTest, StreamVideoDrawQuad) { |
CREATE_QUAD_4_NEW( |
StreamVideoDrawQuad, opaque_rect, visible_rect, resource_id, matrix); |
EXPECT_EQ(resource_id, quad_new->resource_id); |
- EXPECT_EQ(1, IterateAndCount(quad_new.get())); |
+ EXPECT_EQ(1, IterateAndCount(quad_new)); |
EXPECT_EQ(resource_id + 1, quad_new->resource_id); |
} |
@@ -806,7 +872,7 @@ TEST_F(DrawQuadIteratorTest, SurfaceDrawQuad) { |
CREATE_SHARED_STATE(); |
CREATE_QUAD_2_NEW(SurfaceDrawQuad, visible_rect, surface_id); |
- EXPECT_EQ(0, IterateAndCount(quad_new.get())); |
+ EXPECT_EQ(0, IterateAndCount(quad_new)); |
} |
TEST_F(DrawQuadIteratorTest, TextureDrawQuad) { |
@@ -831,7 +897,7 @@ TEST_F(DrawQuadIteratorTest, TextureDrawQuad) { |
vertex_opacity, |
flipped); |
EXPECT_EQ(resource_id, quad_new->resource_id); |
- EXPECT_EQ(1, IterateAndCount(quad_new.get())); |
+ EXPECT_EQ(1, IterateAndCount(quad_new)); |
EXPECT_EQ(resource_id + 1, quad_new->resource_id); |
} |
@@ -852,7 +918,7 @@ TEST_F(DrawQuadIteratorTest, TileDrawQuad) { |
texture_size, |
swizzle_contents); |
EXPECT_EQ(resource_id, quad_new->resource_id); |
- EXPECT_EQ(1, IterateAndCount(quad_new.get())); |
+ EXPECT_EQ(1, IterateAndCount(quad_new)); |
EXPECT_EQ(resource_id + 1, quad_new->resource_id); |
} |
@@ -882,7 +948,7 @@ TEST_F(DrawQuadIteratorTest, YUVVideoDrawQuad) { |
EXPECT_EQ(v_plane_resource_id, quad_new->v_plane_resource_id); |
EXPECT_EQ(a_plane_resource_id, quad_new->a_plane_resource_id); |
EXPECT_EQ(color_space, quad_new->color_space); |
- EXPECT_EQ(4, IterateAndCount(quad_new.get())); |
+ EXPECT_EQ(4, IterateAndCount(quad_new)); |
EXPECT_EQ(y_plane_resource_id + 1, quad_new->y_plane_resource_id); |
EXPECT_EQ(u_plane_resource_id + 1, quad_new->u_plane_resource_id); |
EXPECT_EQ(v_plane_resource_id + 1, quad_new->v_plane_resource_id); |
@@ -910,7 +976,7 @@ TEST_F(DrawQuadIteratorTest, DISABLED_PictureDrawQuad) { |
content_rect, |
contents_scale, |
picture_pile); |
- EXPECT_EQ(0, IterateAndCount(quad_new.get())); |
+ EXPECT_EQ(0, IterateAndCount(quad_new)); |
} |
} // namespace |