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

Side by Side Diff: ppapi/thunk/ppb_talk_private_thunk.cc

Issue 10081020: PPAPI: Make blocking completion callbacks work. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Updated TestURLLoader to test blocking callbacks. Created 8 years, 8 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 | Annotate | Revision Log
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/c/pp_errors.h" 5 #include "ppapi/c/pp_errors.h"
6 #include "ppapi/c/private/ppb_talk_private.h" 6 #include "ppapi/c/private/ppb_talk_private.h"
7 #include "ppapi/thunk/enter.h" 7 #include "ppapi/thunk/enter.h"
8 #include "ppapi/thunk/ppb_talk_private_api.h" 8 #include "ppapi/thunk/ppb_talk_private_api.h"
9 #include "ppapi/thunk/thunk.h" 9 #include "ppapi/thunk/thunk.h"
10 10
11 namespace ppapi { 11 namespace ppapi {
12 namespace thunk { 12 namespace thunk {
13 13
14 namespace { 14 namespace {
15 15
16 PP_Resource Create(PP_Instance instance) { 16 PP_Resource Create(PP_Instance instance) {
17 EnterResourceCreation enter(instance); 17 EnterResourceCreation enter(instance);
18 if (enter.failed()) 18 if (enter.failed())
19 return 0; 19 return 0;
20 return enter.functions()->CreateTalk(instance); 20 return enter.functions()->CreateTalk(instance);
21 } 21 }
22 22
23 int32_t GetPermission(PP_Resource resource, 23 int32_t GetPermission(PP_Resource resource,
24 PP_CompletionCallback callback) { 24 PP_CompletionCallback callback) {
25 EnterResource<PPB_Talk_Private_API> enter(resource, true); 25 EnterResource<PPB_Talk_Private_API> enter(resource, true);
26 if (enter.failed()) 26 if (enter.failed())
27 return PP_ERROR_BADRESOURCE; 27 return PP_ERROR_BADRESOURCE;
28 return enter.object()->GetPermission(callback); 28 return enter.SetResult(enter.object()->GetPermission(enter.callback()));
29 } 29 }
30 30
31 const PPB_Talk_Private_1_0 g_ppb_talk_private_thunk = { 31 const PPB_Talk_Private_1_0 g_ppb_talk_private_thunk = {
32 &Create, 32 &Create,
33 &GetPermission 33 &GetPermission
34 }; 34 };
35 35
36 } // namespace 36 } // namespace
37 37
38 const PPB_Talk_Private_1_0* GetPPB_Talk_Private_1_0_Thunk() { 38 const PPB_Talk_Private_1_0* GetPPB_Talk_Private_1_0_Thunk() {
39 return &g_ppb_talk_private_thunk; 39 return &g_ppb_talk_private_thunk;
40 } 40 }
41 41
42 } // namespace thunk 42 } // namespace thunk
43 } // namespace ppapi 43 } // namespace ppapi
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698