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

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

Issue 10081020: PPAPI: Make blocking completion callbacks work. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: export AssertLockHeld Created 8 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 | Annotate | Revision Log
« no previous file with comments | « ppapi/thunk/ppb_url_loader_api.h ('k') | ppapi/thunk/ppb_video_capture_api.h » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
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_completion_callback.h" 5 #include "ppapi/c/pp_completion_callback.h"
6 #include "ppapi/c/pp_errors.h" 6 #include "ppapi/c/pp_errors.h"
7 #include "ppapi/shared_impl/tracked_callback.h"
7 #include "ppapi/thunk/enter.h" 8 #include "ppapi/thunk/enter.h"
8 #include "ppapi/thunk/thunk.h" 9 #include "ppapi/thunk/thunk.h"
9 #include "ppapi/thunk/ppb_url_loader_api.h" 10 #include "ppapi/thunk/ppb_url_loader_api.h"
10 #include "ppapi/thunk/resource_creation_api.h" 11 #include "ppapi/thunk/resource_creation_api.h"
11 12
12 namespace ppapi { 13 namespace ppapi {
13 namespace thunk { 14 namespace thunk {
14 15
15 namespace { 16 namespace {
16 17
(...skipping 10 matching lines...) Expand all
27 EnterURLLoader enter(resource, false); 28 EnterURLLoader enter(resource, false);
28 return PP_FromBool(enter.succeeded()); 29 return PP_FromBool(enter.succeeded());
29 } 30 }
30 31
31 int32_t Open(PP_Resource loader, 32 int32_t Open(PP_Resource loader,
32 PP_Resource request_id, 33 PP_Resource request_id,
33 PP_CompletionCallback callback) { 34 PP_CompletionCallback callback) {
34 EnterURLLoader enter(loader, callback, true); 35 EnterURLLoader enter(loader, callback, true);
35 if (enter.failed()) 36 if (enter.failed())
36 return enter.retval(); 37 return enter.retval();
37 return enter.SetResult(enter.object()->Open(request_id, callback)); 38 return enter.SetResult(enter.object()->Open(request_id, enter.callback()));
38 } 39 }
39 40
40 int32_t FollowRedirect(PP_Resource loader, 41 int32_t FollowRedirect(PP_Resource loader,
41 PP_CompletionCallback callback) { 42 PP_CompletionCallback callback) {
42 EnterURLLoader enter(loader, callback, true); 43 EnterURLLoader enter(loader, callback, true);
43 if (enter.failed()) 44 if (enter.failed())
44 return enter.retval(); 45 return enter.retval();
45 return enter.SetResult(enter.object()->FollowRedirect(callback)); 46 return enter.SetResult(enter.object()->FollowRedirect(enter.callback()));
46 } 47 }
47 48
48 PP_Bool GetUploadProgress(PP_Resource loader, 49 PP_Bool GetUploadProgress(PP_Resource loader,
49 int64_t* bytes_sent, 50 int64_t* bytes_sent,
50 int64_t* total_bytes_to_be_sent) { 51 int64_t* total_bytes_to_be_sent) {
51 EnterURLLoader enter(loader, true); 52 EnterURLLoader enter(loader, true);
52 if (enter.failed()) { 53 if (enter.failed()) {
53 *bytes_sent = 0; 54 *bytes_sent = 0;
54 *total_bytes_to_be_sent = 0; 55 *total_bytes_to_be_sent = 0;
55 return PP_FALSE; 56 return PP_FALSE;
(...skipping 23 matching lines...) Expand all
79 } 80 }
80 81
81 int32_t ReadResponseBody(PP_Resource loader, 82 int32_t ReadResponseBody(PP_Resource loader,
82 void* buffer, 83 void* buffer,
83 int32_t bytes_to_read, 84 int32_t bytes_to_read,
84 PP_CompletionCallback callback) { 85 PP_CompletionCallback callback) {
85 EnterURLLoader enter(loader, callback, true); 86 EnterURLLoader enter(loader, callback, true);
86 if (enter.failed()) 87 if (enter.failed())
87 return enter.retval(); 88 return enter.retval();
88 return enter.SetResult(enter.object()->ReadResponseBody(buffer, bytes_to_read, 89 return enter.SetResult(enter.object()->ReadResponseBody(buffer, bytes_to_read,
89 callback)); 90 enter.callback()));
90 } 91 }
91 92
92 int32_t FinishStreamingToFile(PP_Resource loader, 93 int32_t FinishStreamingToFile(PP_Resource loader,
93 PP_CompletionCallback callback) { 94 PP_CompletionCallback callback) {
94 EnterURLLoader enter(loader, callback, true); 95 EnterURLLoader enter(loader, callback, true);
95 if (enter.failed()) 96 if (enter.failed())
96 return enter.retval(); 97 return enter.retval();
97 return enter.SetResult(enter.object()->FinishStreamingToFile(callback)); 98 return enter.SetResult(
99 enter.object()->FinishStreamingToFile(enter.callback()));
98 } 100 }
99 101
100 void Close(PP_Resource loader) { 102 void Close(PP_Resource loader) {
101 EnterURLLoader enter(loader, true); 103 EnterURLLoader enter(loader, true);
102 if (enter.succeeded()) 104 if (enter.succeeded())
103 enter.object()->Close(); 105 enter.object()->Close();
104 } 106 }
105 107
106 void GrantUniversalAccess(PP_Resource loader) { 108 void GrantUniversalAccess(PP_Resource loader) {
107 EnterURLLoader enter(loader, true); 109 EnterURLLoader enter(loader, true);
(...skipping 31 matching lines...) Expand 10 before | Expand all | Expand 10 after
139 const PPB_URLLoader_1_0* GetPPB_URLLoader_1_0_Thunk() { 141 const PPB_URLLoader_1_0* GetPPB_URLLoader_1_0_Thunk() {
140 return &g_ppb_urlloader_thunk; 142 return &g_ppb_urlloader_thunk;
141 } 143 }
142 144
143 const PPB_URLLoaderTrusted_0_3* GetPPB_URLLoaderTrusted_0_3_Thunk() { 145 const PPB_URLLoaderTrusted_0_3* GetPPB_URLLoaderTrusted_0_3_Thunk() {
144 return &g_ppb_urlloader_trusted_thunk; 146 return &g_ppb_urlloader_trusted_thunk;
145 } 147 }
146 148
147 } // namespace thunk 149 } // namespace thunk
148 } // namespace ppapi 150 } // namespace ppapi
OLDNEW
« no previous file with comments | « ppapi/thunk/ppb_url_loader_api.h ('k') | ppapi/thunk/ppb_video_capture_api.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698