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

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: 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_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/thunk/enter.h" 7 #include "ppapi/thunk/enter.h"
8 #include "ppapi/thunk/thunk.h" 8 #include "ppapi/thunk/thunk.h"
9 #include "ppapi/thunk/ppb_url_loader_api.h" 9 #include "ppapi/thunk/ppb_url_loader_api.h"
10 #include "ppapi/thunk/resource_creation_api.h" 10 #include "ppapi/thunk/resource_creation_api.h"
(...skipping 16 matching lines...) Expand all
27 EnterURLLoader enter(resource, false); 27 EnterURLLoader enter(resource, false);
28 return PP_FromBool(enter.succeeded()); 28 return PP_FromBool(enter.succeeded());
29 } 29 }
30 30
31 int32_t Open(PP_Resource loader, 31 int32_t Open(PP_Resource loader,
32 PP_Resource request_id, 32 PP_Resource request_id,
33 PP_CompletionCallback callback) { 33 PP_CompletionCallback callback) {
34 EnterURLLoader enter(loader, callback, true); 34 EnterURLLoader enter(loader, callback, true);
35 if (enter.failed()) 35 if (enter.failed())
36 return enter.retval(); 36 return enter.retval();
37 return enter.SetResult(enter.object()->Open(request_id, callback)); 37 return enter.SetResult(enter.object()->Open(request_id, enter.callback()));
38 } 38 }
39 39
40 int32_t FollowRedirect(PP_Resource loader, 40 int32_t FollowRedirect(PP_Resource loader,
41 PP_CompletionCallback callback) { 41 PP_CompletionCallback callback) {
42 EnterURLLoader enter(loader, callback, true); 42 EnterURLLoader enter(loader, callback, true);
43 if (enter.failed()) 43 if (enter.failed())
44 return enter.retval(); 44 return enter.retval();
45 return enter.SetResult(enter.object()->FollowRedirect(callback)); 45 return enter.SetResult(enter.object()->FollowRedirect(enter.callback()));
46 } 46 }
47 47
48 PP_Bool GetUploadProgress(PP_Resource loader, 48 PP_Bool GetUploadProgress(PP_Resource loader,
49 int64_t* bytes_sent, 49 int64_t* bytes_sent,
50 int64_t* total_bytes_to_be_sent) { 50 int64_t* total_bytes_to_be_sent) {
51 EnterURLLoader enter(loader, true); 51 EnterURLLoader enter(loader, true);
52 if (enter.failed()) { 52 if (enter.failed()) {
53 *bytes_sent = 0; 53 *bytes_sent = 0;
54 *total_bytes_to_be_sent = 0; 54 *total_bytes_to_be_sent = 0;
55 return PP_FALSE; 55 return PP_FALSE;
(...skipping 23 matching lines...) Expand all
79 } 79 }
80 80
81 int32_t ReadResponseBody(PP_Resource loader, 81 int32_t ReadResponseBody(PP_Resource loader,
82 void* buffer, 82 void* buffer,
83 int32_t bytes_to_read, 83 int32_t bytes_to_read,
84 PP_CompletionCallback callback) { 84 PP_CompletionCallback callback) {
85 EnterURLLoader enter(loader, callback, true); 85 EnterURLLoader enter(loader, callback, true);
86 if (enter.failed()) 86 if (enter.failed())
87 return enter.retval(); 87 return enter.retval();
88 return enter.SetResult(enter.object()->ReadResponseBody(buffer, bytes_to_read, 88 return enter.SetResult(enter.object()->ReadResponseBody(buffer, bytes_to_read,
89 callback)); 89 enter.callback()));
90 } 90 }
91 91
92 int32_t FinishStreamingToFile(PP_Resource loader, 92 int32_t FinishStreamingToFile(PP_Resource loader,
93 PP_CompletionCallback callback) { 93 PP_CompletionCallback callback) {
94 EnterURLLoader enter(loader, callback, true); 94 EnterURLLoader enter(loader, callback, true);
95 if (enter.failed()) 95 if (enter.failed())
96 return enter.retval(); 96 return enter.retval();
97 return enter.SetResult(enter.object()->FinishStreamingToFile(callback)); 97 return enter.SetResult(
98 enter.object()->FinishStreamingToFile(enter.callback()));
98 } 99 }
99 100
100 void Close(PP_Resource loader) { 101 void Close(PP_Resource loader) {
101 EnterURLLoader enter(loader, true); 102 EnterURLLoader enter(loader, true);
102 if (enter.succeeded()) 103 if (enter.succeeded())
103 enter.object()->Close(); 104 enter.object()->Close();
104 } 105 }
105 106
106 void GrantUniversalAccess(PP_Resource loader) { 107 void GrantUniversalAccess(PP_Resource loader) {
107 EnterURLLoader enter(loader, true); 108 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() { 140 const PPB_URLLoader_1_0* GetPPB_URLLoader_1_0_Thunk() {
140 return &g_ppb_urlloader_thunk; 141 return &g_ppb_urlloader_thunk;
141 } 142 }
142 143
143 const PPB_URLLoaderTrusted_0_3* GetPPB_URLLoaderTrusted_0_3_Thunk() { 144 const PPB_URLLoaderTrusted_0_3* GetPPB_URLLoaderTrusted_0_3_Thunk() {
144 return &g_ppb_urlloader_trusted_thunk; 145 return &g_ppb_urlloader_trusted_thunk;
145 } 146 }
146 147
147 } // namespace thunk 148 } // namespace thunk
148 } // namespace ppapi 149 } // namespace ppapi
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698