diff options
author | csilv@chromium.org <csilv@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2011-10-12 17:07:47 +0000 |
---|---|---|
committer | csilv@chromium.org <csilv@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2011-10-12 17:07:47 +0000 |
commit | 2d300e710abab2137223ad48be681387efd9550d (patch) | |
tree | eee5de75e1a83adb245ec6d4f2d8b69f85e87f99 | |
parent | c4170c98f76cc7d6bf4eddd13291884b3523010b (diff) | |
download | chromium_src-2d300e710abab2137223ad48be681387efd9550d.zip chromium_src-2d300e710abab2137223ad48be681387efd9550d.tar.gz chromium_src-2d300e710abab2137223ad48be681387efd9550d.tar.bz2 |
[web-ui] Remove support for legacy-style callbacks.
BUG=98478
Review URL: http://codereview.chromium.org/8199011
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@105105 0039d316-1c4b-4281-b951-d872f2087c98
-rw-r--r-- | content/browser/webui/web_ui.cc | 38 | ||||
-rw-r--r-- | content/browser/webui/web_ui.h | 21 |
2 files changed, 10 insertions, 49 deletions
diff --git a/content/browser/webui/web_ui.cc b/content/browser/webui/web_ui.cc index 206d221..92e55c9 100644 --- a/content/browser/webui/web_ui.cc +++ b/content/browser/webui/web_ui.cc @@ -52,9 +52,6 @@ WebUI::WebUI(TabContents* contents) } WebUI::~WebUI() { - // TODO(csilv): Remove legacy callback support. - STLDeleteContainerPairSecondPointers(message_callbacks_.begin(), - message_callbacks_.end()); STLDeleteContainerPointers(handlers_.begin(), handlers_.end()); } @@ -81,21 +78,11 @@ void WebUI::OnWebUISend(const GURL& source_url, } // Look up the callback for this message. - NewMessageCallbackMap::const_iterator new_callback = - new_message_callbacks_.find(message); - if (new_callback != new_message_callbacks_.end()) { - // Forward this message and content on. - new_callback->second.Run(&args); - return; - } - - // TODO(csilv): Remove legacy callback support. - // Look up the callback for this message. MessageCallbackMap::const_iterator callback = message_callbacks_.find(message); if (callback != message_callbacks_.end()) { // Forward this message and content on. - callback->second->Run(&args); + callback->second.Run(&args); } } @@ -170,30 +157,13 @@ void WebUI::CallJavascriptFunction( } void WebUI::RegisterMessageCallback(const std::string &message, - const NewMessageCallback& callback) { - std::pair<NewMessageCallbackMap::iterator, bool> result = - new_message_callbacks_.insert(std::make_pair(message, callback)); - - // Overwrite preexisting message callback mappings. - if (!result.second && register_callback_overwrites()) - result.first->second = callback; -} - -// TODO(csilv): Remove legacy callback support. -void WebUI::RegisterMessageCallback(const std::string& message, - MessageCallback* callback) { + const MessageCallback& callback) { std::pair<MessageCallbackMap::iterator, bool> result = message_callbacks_.insert(std::make_pair(message, callback)); // Overwrite preexisting message callback mappings. - if (!result.second) { - if (register_callback_overwrites()) { - delete result.first->second; - result.first->second = callback; - } else { - delete callback; - } - } + if (!result.second && register_callback_overwrites()) + result.first->second = callback; } bool WebUI::IsLoading() const { diff --git a/content/browser/webui/web_ui.h b/content/browser/webui/web_ui.h index 6d0e16c..7c5b270 100644 --- a/content/browser/webui/web_ui.h +++ b/content/browser/webui/web_ui.h @@ -66,17 +66,12 @@ class CONTENT_EXPORT WebUI : public IPC::Channel::Listener { // won't be run in that case. virtual void DidBecomeActiveForReusedRenderView() {} - // Used by WebUIMessageHandlers. RegisterMessageCallback takes ownership of - // the passed callback. If the given message is already registered, the call - // has no effect unless |register_callback_overwrites_| is set to true. - typedef base::Callback<void(const base::ListValue*)> NewMessageCallback; + // Used by WebUIMessageHandlers. If the given message is already registered, + // the call has no effect unless |register_callback_overwrites_| is set to + // true. + typedef base::Callback<void(const base::ListValue*)> MessageCallback; void RegisterMessageCallback(const std::string& message, - const NewMessageCallback& callback); - - // TODO(csilv): Remove legacy callback support - typedef Callback1<const base::ListValue*>::Type MessageCallback; - void RegisterMessageCallback(const std::string& message, - MessageCallback* callback); + const MessageCallback& callback); // Returns true if the favicon should be hidden for the current tab. bool hide_favicon() const { @@ -196,11 +191,7 @@ class CONTENT_EXPORT WebUI : public IPC::Channel::Listener { private: // A map of message name -> message handling callback. - typedef std::map<std::string, NewMessageCallback> NewMessageCallbackMap; - NewMessageCallbackMap new_message_callbacks_; - - // TODO(csilv): Remove legacy callback support. - typedef std::map<std::string, MessageCallback*> MessageCallbackMap; + typedef std::map<std::string, MessageCallback> MessageCallbackMap; MessageCallbackMap message_callbacks_; DISALLOW_COPY_AND_ASSIGN(WebUI); |