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

Side by Side Diff: ppapi/proxy/ppb_instance_proxy.cc

Issue 324983005: [PPAPI] Add browser tests for compositor API (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@compositor_api_impl_new
Patch Set: Rebase Created 6 years, 6 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 unified diff | Download patch
OLDNEW
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #include "ppapi/proxy/ppb_instance_proxy.h" 5 #include "ppapi/proxy/ppb_instance_proxy.h"
6 6
7 #include "base/memory/ref_counted.h" 7 #include "base/memory/ref_counted.h"
8 #include "build/build_config.h" 8 #include "build/build_config.h"
9 #include "ppapi/c/pp_errors.h" 9 #include "ppapi/c/pp_errors.h"
10 #include "ppapi/c/pp_time.h" 10 #include "ppapi/c/pp_time.h"
(...skipping 197 matching lines...) Expand 10 before | Expand all | Expand 10 after
208 208
209 IPC_MESSAGE_UNHANDLED(handled = false) 209 IPC_MESSAGE_UNHANDLED(handled = false)
210 IPC_END_MESSAGE_MAP() 210 IPC_END_MESSAGE_MAP()
211 return handled; 211 return handled;
212 } 212 }
213 213
214 PP_Bool PPB_Instance_Proxy::BindGraphics(PP_Instance instance, 214 PP_Bool PPB_Instance_Proxy::BindGraphics(PP_Instance instance,
215 PP_Resource device) { 215 PP_Resource device) {
216 // If device is 0, pass a null HostResource. This signals the host to unbind 216 // If device is 0, pass a null HostResource. This signals the host to unbind
217 // all devices. 217 // all devices.
218 HostResource host_resource;
219 PP_Resource pp_resource = 0; 218 PP_Resource pp_resource = 0;
219 InstanceData* data = static_cast<PluginDispatcher*>(dispatcher())->
220 GetInstanceData(instance);
221 scoped_refptr<Resource> old_compositor = data->bound_compositor;
222
220 if (device) { 223 if (device) {
221 Resource* resource = 224 do {
222 PpapiGlobals::Get()->GetResourceTracker()->GetResource(device); 225 // Try enter device as a Graphics3D deivce.
223 if (!resource || resource->pp_instance() != instance) 226 EnterResourceNoLock<PPB_Graphics3D_API> enter_3d(device, false);
227 if (enter_3d.succeeded()) {
228 if (enter_3d.resource()->pp_instance() != instance)
229 return PP_FALSE;
230 data->bound_compositor = NULL;
231 pp_resource = enter_3d.resource()->host_resource().host_resource();
232 break;
233 }
234
235 // Try enter device as a Graphics2D device.
236 EnterResourceNoLock<PPB_Graphics2D_API> enter_2d(device, false);
237 if (enter_2d.succeeded()) {
238 if (enter_2d.resource()->pp_instance() != instance)
239 return PP_FALSE;
240 data->bound_compositor = NULL;
241 pp_resource = enter_2d.resource()->pp_resource();
242 break;
243 }
244
245 // Try enter device as a Compositor device.
246 EnterResourceNoLock<PPB_Compositor_API> enter_compositor(device, false);
247 if (enter_compositor.succeeded()) {
248 if (enter_compositor.resource()->pp_instance() != instance)
249 return PP_FALSE;
250 data->bound_compositor = enter_compositor.resource();
251 pp_resource = enter_compositor.resource()->pp_resource();
252 break;
253 }
254
224 return PP_FALSE; 255 return PP_FALSE;
225 host_resource = resource->host_resource(); 256 } while (false);
piman 2014/06/18 00:55:24 That's a crazy amount of logic to track something
Peng 2014/06/18 02:35:03 Same reason. And EnterResourceNoLock() will look u
226 pp_resource = resource->pp_resource();
227 } else { 257 } else {
228 // Passing 0 means unbinding all devices. 258 data->bound_compositor = NULL;
229 dispatcher()->Send(new PpapiHostMsg_PPBInstance_BindGraphics(
230 API_ID_PPB_INSTANCE, instance, 0));
231 return PP_TRUE;
232 } 259 }
233 260
234 // We need to pass different resource to Graphics 2D and 3D right now. Once 261 if (old_compositor)
235 // 3D is migrated to the new design, we should be able to unify this. 262 old_compositor->AsPPB_Compositor_API()->BindToInstance(0);
236 EnterResourceNoLock<PPB_Compositor_API> enter_compositor(device, false); 263
237 EnterResourceNoLock<PPB_Graphics2D_API> enter_2d(device, false); 264 if (data->bound_compositor)
238 EnterResourceNoLock<PPB_Graphics3D_API> enter_3d(device, false); 265 data->bound_compositor->AsPPB_Compositor_API()->BindToInstance(true);
239 if (enter_compositor.succeeded() || enter_2d.succeeded()) { 266
240 dispatcher()->Send(new PpapiHostMsg_PPBInstance_BindGraphics( 267 dispatcher()->Send(new PpapiHostMsg_PPBInstance_BindGraphics(
241 API_ID_PPB_INSTANCE, instance, pp_resource)); 268 API_ID_PPB_INSTANCE, instance, pp_resource));
242 return PP_TRUE; 269
243 } else if (enter_3d.succeeded()) { 270 return PP_TRUE;
244 dispatcher()->Send(new PpapiHostMsg_PPBInstance_BindGraphics(
245 API_ID_PPB_INSTANCE, instance, host_resource.host_resource()));
246 return PP_TRUE;
247 }
248 return PP_FALSE;
249 } 271 }
250 272
251 PP_Bool PPB_Instance_Proxy::IsFullFrame(PP_Instance instance) { 273 PP_Bool PPB_Instance_Proxy::IsFullFrame(PP_Instance instance) {
252 PP_Bool result = PP_FALSE; 274 PP_Bool result = PP_FALSE;
253 dispatcher()->Send(new PpapiHostMsg_PPBInstance_IsFullFrame( 275 dispatcher()->Send(new PpapiHostMsg_PPBInstance_IsFullFrame(
254 API_ID_PPB_INSTANCE, instance, &result)); 276 API_ID_PPB_INSTANCE, instance, &result));
255 return result; 277 return result;
256 } 278 }
257 279
258 const ViewData* PPB_Instance_Proxy::GetViewData(PP_Instance instance) { 280 const ViewData* PPB_Instance_Proxy::GetViewData(PP_Instance instance) {
(...skipping 1171 matching lines...) Expand 10 before | Expand all | Expand 10 after
1430 PP_Instance instance) { 1452 PP_Instance instance) {
1431 InstanceData* data = static_cast<PluginDispatcher*>(dispatcher())-> 1453 InstanceData* data = static_cast<PluginDispatcher*>(dispatcher())->
1432 GetInstanceData(instance); 1454 GetInstanceData(instance);
1433 if (!data) 1455 if (!data)
1434 return; // Instance was probably deleted. 1456 return; // Instance was probably deleted.
1435 data->should_do_request_surrounding_text = false; 1457 data->should_do_request_surrounding_text = false;
1436 } 1458 }
1437 1459
1438 } // namespace proxy 1460 } // namespace proxy
1439 } // namespace ppapi 1461 } // namespace ppapi
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698