OLD | NEW |
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 Loading... |
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 Loading... |
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 Loading... |
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 |
OLD | NEW |