Index: ppapi/cpp/compositor_layer.cc |
diff --git a/ppapi/cpp/compositor_layer.cc b/ppapi/cpp/compositor_layer.cc |
index cbe823a3ac017b269feae6b0d2de08368f007658..d15a6731ba5b1abd4fc5ca5076e3973c83a1cd86 100644 |
--- a/ppapi/cpp/compositor_layer.cc |
+++ b/ppapi/cpp/compositor_layer.cc |
@@ -17,6 +17,10 @@ template <> const char* interface_name<PPB_CompositorLayer_0_1>() { |
return PPB_COMPOSITORLAYER_INTERFACE_0_1; |
} |
+template <> const char* interface_name<PPB_CompositorLayer_0_2>() { |
+ return PPB_COMPOSITORLAYER_INTERFACE_0_2; |
+} |
+ |
} // namespace |
CompositorLayer::CompositorLayer() { |
@@ -43,6 +47,10 @@ int32_t CompositorLayer::SetColor(float red, |
float blue, |
float alpha, |
const Size& size) { |
+ if (has_interface<PPB_CompositorLayer_0_2>()) { |
+ return get_interface<PPB_CompositorLayer_0_2>()->SetColor( |
+ pp_resource(), red, green, blue, alpha, &size.pp_size()); |
+ } |
if (has_interface<PPB_CompositorLayer_0_1>()) { |
return get_interface<PPB_CompositorLayer_0_1>()->SetColor( |
pp_resource(), red, green, blue, alpha, &size.pp_size()); |
@@ -51,10 +59,18 @@ int32_t CompositorLayer::SetColor(float red, |
} |
int32_t CompositorLayer::SetTexture(const Graphics3D& context, |
+ uint32_t target, |
uint32_t texture, |
const Size& size, |
const CompletionCallback& cc) { |
+ if (has_interface<PPB_CompositorLayer_0_2>()) { |
+ return get_interface<PPB_CompositorLayer_0_2>()->SetTexture( |
+ pp_resource(), context.pp_resource(), target, texture, &size.pp_size(), |
+ cc.pp_completion_callback()); |
+ } |
if (has_interface<PPB_CompositorLayer_0_1>()) { |
+ if (target != 0x0DE1) // 0x0DE1 GL_TEXTURE_2D |
+ return cc.MayForce(PP_ERROR_NOTSUPPORTED); |
return get_interface<PPB_CompositorLayer_0_1>()->SetTexture( |
pp_resource(), context.pp_resource(), texture, &size.pp_size(), |
cc.pp_completion_callback()); |
@@ -64,6 +80,11 @@ int32_t CompositorLayer::SetTexture(const Graphics3D& context, |
int32_t CompositorLayer::SetImage(const ImageData& image, |
const CompletionCallback& cc) { |
+ if (has_interface<PPB_CompositorLayer_0_2>()) { |
+ return get_interface<PPB_CompositorLayer_0_2>()->SetImage( |
+ pp_resource(), image.pp_resource(), NULL, |
+ cc.pp_completion_callback()); |
+ } |
if (has_interface<PPB_CompositorLayer_0_1>()) { |
return get_interface<PPB_CompositorLayer_0_1>()->SetImage( |
pp_resource(), image.pp_resource(), NULL, |
@@ -75,6 +96,11 @@ int32_t CompositorLayer::SetImage(const ImageData& image, |
int32_t CompositorLayer::SetImage(const ImageData& image, |
const Size& size, |
const CompletionCallback& cc) { |
+ if (has_interface<PPB_CompositorLayer_0_2>()) { |
+ return get_interface<PPB_CompositorLayer_0_2>()->SetImage( |
+ pp_resource(), image.pp_resource(), &size.pp_size(), |
+ cc.pp_completion_callback()); |
+ } |
if (has_interface<PPB_CompositorLayer_0_1>()) { |
return get_interface<PPB_CompositorLayer_0_1>()->SetImage( |
pp_resource(), image.pp_resource(), &size.pp_size(), |
@@ -84,6 +110,10 @@ int32_t CompositorLayer::SetImage(const ImageData& image, |
} |
int32_t CompositorLayer::SetClipRect(const Rect& rect) { |
+ if (has_interface<PPB_CompositorLayer_0_2>()) { |
+ return get_interface<PPB_CompositorLayer_0_2>()->SetClipRect( |
+ pp_resource(), &rect.pp_rect()); |
+ } |
if (has_interface<PPB_CompositorLayer_0_1>()) { |
return get_interface<PPB_CompositorLayer_0_1>()->SetClipRect( |
pp_resource(), &rect.pp_rect()); |
@@ -92,6 +122,10 @@ int32_t CompositorLayer::SetClipRect(const Rect& rect) { |
} |
int32_t CompositorLayer::SetTransform(const float matrix[16]) { |
+ if (has_interface<PPB_CompositorLayer_0_2>()) { |
+ return get_interface<PPB_CompositorLayer_0_2>()->SetTransform( |
+ pp_resource(), matrix); |
+ } |
if (has_interface<PPB_CompositorLayer_0_1>()) { |
return get_interface<PPB_CompositorLayer_0_1>()->SetTransform( |
pp_resource(), matrix); |
@@ -100,6 +134,10 @@ int32_t CompositorLayer::SetTransform(const float matrix[16]) { |
} |
int32_t CompositorLayer::SetOpacity(float opacity) { |
+ if (has_interface<PPB_CompositorLayer_0_2>()) { |
+ return get_interface<PPB_CompositorLayer_0_2>()->SetOpacity( |
+ pp_resource(), opacity); |
+ } |
if (has_interface<PPB_CompositorLayer_0_1>()) { |
return get_interface<PPB_CompositorLayer_0_1>()->SetOpacity( |
pp_resource(), opacity); |
@@ -108,6 +146,10 @@ int32_t CompositorLayer::SetOpacity(float opacity) { |
} |
int32_t CompositorLayer::SetBlendMode(PP_BlendMode mode) { |
+ if (has_interface<PPB_CompositorLayer_0_2>()) { |
+ return get_interface<PPB_CompositorLayer_0_2>()->SetBlendMode( |
+ pp_resource(), mode); |
+ } |
if (has_interface<PPB_CompositorLayer_0_1>()) { |
return get_interface<PPB_CompositorLayer_0_1>()->SetBlendMode( |
pp_resource(), mode); |
@@ -116,6 +158,10 @@ int32_t CompositorLayer::SetBlendMode(PP_BlendMode mode) { |
} |
int32_t CompositorLayer::SetSourceRect(const FloatRect& rect) { |
+ if (has_interface<PPB_CompositorLayer_0_2>()) { |
+ return get_interface<PPB_CompositorLayer_0_2>()->SetSourceRect( |
+ pp_resource(), &rect.pp_float_rect()); |
+ } |
if (has_interface<PPB_CompositorLayer_0_1>()) { |
return get_interface<PPB_CompositorLayer_0_1>()->SetSourceRect( |
pp_resource(), &rect.pp_float_rect()); |
@@ -124,6 +170,10 @@ int32_t CompositorLayer::SetSourceRect(const FloatRect& rect) { |
} |
int32_t CompositorLayer::SetPremultipliedAlpha(bool premult) { |
+ if (has_interface<PPB_CompositorLayer_0_2>()) { |
+ return get_interface<PPB_CompositorLayer_0_2>()->SetPremultipliedAlpha( |
+ pp_resource(), PP_FromBool(premult)); |
+ } |
if (has_interface<PPB_CompositorLayer_0_1>()) { |
return get_interface<PPB_CompositorLayer_0_1>()->SetPremultipliedAlpha( |
pp_resource(), PP_FromBool(premult)); |
@@ -132,6 +182,10 @@ int32_t CompositorLayer::SetPremultipliedAlpha(bool premult) { |
} |
bool CompositorLayer::IsCompositorLayer(const Resource& resource) { |
+ if (has_interface<PPB_CompositorLayer_0_2>()) { |
+ return PP_ToBool(get_interface<PPB_CompositorLayer_0_2>()-> |
+ IsCompositorLayer(resource.pp_resource())); |
+ } |
if (has_interface<PPB_CompositorLayer_0_1>()) { |
return PP_ToBool(get_interface<PPB_CompositorLayer_0_1>()-> |
IsCompositorLayer(resource.pp_resource())); |