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

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

Issue 7585025: Reland 95309. Add a template to handle properly issuing completion callbacks. (Closed) Base URL: svn://chrome-svn/chrome/trunk/src/
Patch Set: Created 9 years, 4 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/proxy/ppb_file_system_proxy.cc ('k') | ppapi/proxy/ppb_graphics_2d_proxy.cc » ('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) 2011 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2011 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_flash_menu_proxy.h" 5 #include "ppapi/proxy/ppb_flash_menu_proxy.h"
6 6
7 #include "ppapi/c/pp_errors.h" 7 #include "ppapi/c/pp_errors.h"
8 #include "ppapi/c/private/ppb_flash_menu.h" 8 #include "ppapi/c/private/ppb_flash_menu.h"
9 #include "ppapi/proxy/enter_proxy.h" 9 #include "ppapi/proxy/enter_proxy.h"
10 #include "ppapi/proxy/ppapi_messages.h" 10 #include "ppapi/proxy/ppapi_messages.h"
(...skipping 144 matching lines...) Expand 10 before | Expand all | Expand 10 after
155 155
156 struct PPB_Flash_Menu_Proxy::ShowRequest { 156 struct PPB_Flash_Menu_Proxy::ShowRequest {
157 HostResource menu; 157 HostResource menu;
158 int32_t selected_id; 158 int32_t selected_id;
159 }; 159 };
160 160
161 void PPB_Flash_Menu_Proxy::OnMsgShow(const HostResource& menu, 161 void PPB_Flash_Menu_Proxy::OnMsgShow(const HostResource& menu,
162 const PP_Point& location) { 162 const PP_Point& location) {
163 ShowRequest* request = new ShowRequest; 163 ShowRequest* request = new ShowRequest;
164 request->menu = menu; 164 request->menu = menu;
165 CompletionCallback callback = callback_factory_.NewOptionalCallback(
166 &PPB_Flash_Menu_Proxy::SendShowACKToPlugin, request);
167 165
168 EnterHostFromHostResource<PPB_Flash_Menu_API> enter(menu); 166 EnterHostFromHostResourceForceCallback<PPB_Flash_Menu_API> enter(
169 int32_t result = PP_ERROR_BADRESOURCE; 167 menu, callback_factory_, &PPB_Flash_Menu_Proxy::SendShowACKToPlugin,
168 request);
170 if (enter.succeeded()) { 169 if (enter.succeeded()) {
171 result = enter.object()->Show(&location, 170 enter.SetResult(enter.object()->Show(&location, &request->selected_id,
172 &request->selected_id, 171 enter.callback()));
173 callback.pp_completion_callback());
174 }
175 if (result != PP_OK_COMPLETIONPENDING) {
176 // There was some error, so we won't get a callback. We need to now issue
177 // the ACK to the plugin so that it hears about the error. This will also
178 // clean up the data associated with the callback.
179 callback.Run(result);
180 } 172 }
181 } 173 }
182 174
183 void PPB_Flash_Menu_Proxy::OnMsgShowACK(const HostResource& menu, 175 void PPB_Flash_Menu_Proxy::OnMsgShowACK(const HostResource& menu,
184 int32_t selected_id, 176 int32_t selected_id,
185 int32_t result) { 177 int32_t result) {
186 EnterPluginFromHostResource<PPB_Flash_Menu_API> enter(menu); 178 EnterPluginFromHostResource<PPB_Flash_Menu_API> enter(menu);
187 if (enter.failed()) 179 if (enter.failed())
188 return; 180 return;
189 static_cast<FlashMenu*>(enter.object())->ShowACK(selected_id, result); 181 static_cast<FlashMenu*>(enter.object())->ShowACK(selected_id, result);
190 } 182 }
191 183
192 void PPB_Flash_Menu_Proxy::SendShowACKToPlugin( 184 void PPB_Flash_Menu_Proxy::SendShowACKToPlugin(
193 int32_t result, 185 int32_t result,
194 ShowRequest* request) { 186 ShowRequest* request) {
195 dispatcher()->Send(new PpapiMsg_PPBFlashMenu_ShowACK( 187 dispatcher()->Send(new PpapiMsg_PPBFlashMenu_ShowACK(
196 INTERFACE_ID_PPB_FLASH_MENU, 188 INTERFACE_ID_PPB_FLASH_MENU,
197 request->menu, 189 request->menu,
198 request->selected_id, 190 request->selected_id,
199 result)); 191 result));
200 delete request; 192 delete request;
201 } 193 }
202 194
203 } // namespace proxy 195 } // namespace proxy
204 } // namespace pp 196 } // namespace pp
OLDNEW
« no previous file with comments | « ppapi/proxy/ppb_file_system_proxy.cc ('k') | ppapi/proxy/ppb_graphics_2d_proxy.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698