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

Side by Side Diff: chrome/renderer/extensions/request_sender.h

Issue 227413008: Add the feature to retain the user gesture in the extension callback (Closed) Base URL: http://src.chromium.org/svn/trunk/src/
Patch Set: Created 6 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 #ifndef CHROME_RENDERER_EXTENSIONS_REQUEST_SENDER_H_ 5 #ifndef CHROME_RENDERER_EXTENSIONS_REQUEST_SENDER_H_
6 #define CHROME_RENDERER_EXTENSIONS_REQUEST_SENDER_H_ 6 #define CHROME_RENDERER_EXTENSIONS_REQUEST_SENDER_H_
7 7
8 #include <string> 8 #include <string>
9 #include <map> 9 #include <map>
10 10
(...skipping 62 matching lines...) Expand 10 before | Expand all | Expand 10 after
73 const std::string& name, 73 const std::string& name,
74 int request_id, 74 int request_id,
75 bool has_callback, 75 bool has_callback,
76 bool for_io_thread, 76 bool for_io_thread,
77 base::ListValue* value_args); 77 base::ListValue* value_args);
78 78
79 // Handles responses from the extension host to calls made by StartRequest(). 79 // Handles responses from the extension host to calls made by StartRequest().
80 void HandleResponse(int request_id, 80 void HandleResponse(int request_id,
81 bool success, 81 bool success,
82 const base::ListValue& response, 82 const base::ListValue& response,
83 const std::string& error); 83 const std::string& error,
84 bool user_gesture);
84 85
85 // Notifies this that a request source is no longer valid. 86 // Notifies this that a request source is no longer valid.
86 // TODO(kalman): Do this in a generic/safe way. 87 // TODO(kalman): Do this in a generic/safe way.
87 void InvalidateSource(Source* source); 88 void InvalidateSource(Source* source);
88 89
89 private: 90 private:
90 friend class ScopedTabID; 91 friend class ScopedTabID;
91 typedef std::map<int, linked_ptr<PendingRequest> > PendingRequestMap; 92 typedef std::map<int, linked_ptr<PendingRequest> > PendingRequestMap;
92 93
93 void InsertRequest(int request_id, PendingRequest* pending_request); 94 void InsertRequest(int request_id, PendingRequest* pending_request);
94 linked_ptr<PendingRequest> RemoveRequest(int request_id); 95 linked_ptr<PendingRequest> RemoveRequest(int request_id);
95 96
96 Dispatcher* dispatcher_; 97 Dispatcher* dispatcher_;
97 PendingRequestMap pending_requests_; 98 PendingRequestMap pending_requests_;
98 99
99 int source_tab_id_; // Id of the tab sending the request, or -1 if no tab. 100 int source_tab_id_; // Id of the tab sending the request, or -1 if no tab.
100 101
101 DISALLOW_COPY_AND_ASSIGN(RequestSender); 102 DISALLOW_COPY_AND_ASSIGN(RequestSender);
102 }; 103 };
103 104
104 } // namespace extensions 105 } // namespace extensions
105 106
106 #endif // CHROME_RENDERER_EXTENSIONS_REQUEST_SENDER_H_ 107 #endif // CHROME_RENDERER_EXTENSIONS_REQUEST_SENDER_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698