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

Side by Side Diff: chrome/renderer/prerender/prerender_dispatcher.cc

Issue 9416031: Prerendered pages are swapped in at browser::Navigate time. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Remove TODO Created 8 years, 9 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
(Empty)
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
3 // found in the LICENSE file.
4
5 #include "chrome/renderer/prerender/prerender_dispatcher.h"
6
7 #include "base/logging.h"
8 #include "chrome/common/prerender_messages.h"
9 #include "googleurl/src/gurl.h"
10
11 namespace prerender {
12
13 bool PrerenderDispatcher::IsPrerenderURL(const GURL& url) const {
14 return prerender_urls_.find(url) != prerender_urls_.end();
15 }
16
17 bool PrerenderDispatcher::OnControlMessageReceived(
18 const IPC::Message& message) {
19 bool handled = true;
20 IPC_BEGIN_MESSAGE_MAP(PrerenderDispatcher, message)
21 IPC_MESSAGE_HANDLER(PrerenderMsg_AddPrerenderURL, OnAddPrerenderURL)
22 IPC_MESSAGE_HANDLER(PrerenderMsg_RemovePrerenderURL, OnRemovePrerenderURL)
23 IPC_MESSAGE_UNHANDLED(handled = false)
24 IPC_END_MESSAGE_MAP()
25
26 return handled;
27 }
28
29 void PrerenderDispatcher::OnAddPrerenderURL(const GURL& url) {
30 PrerenderMap::iterator it = prerender_urls_.find(url);
31 if (it != prerender_urls_.end()) {
32 DCHECK(it->second > 0);
33 it->second += 1;
34 } else {
35 prerender_urls_[url] = 1;
36 }
37 }
38
39 void PrerenderDispatcher::OnRemovePrerenderURL(const GURL& url) {
40 PrerenderMap::iterator it = prerender_urls_.find(url);
41 // This is possible with a spurious remove.
42 // TODO(cbentzel): We'd also want to send the map of active prerenders when
43 // creating a new render process, so the Add/Remove go relative to that.
44 // This may not be that big of a deal in practice, since the newly created tab
45 // is unlikely to go to the prerendered page.
46 if (it == prerender_urls_.end())
47 return;
48 DCHECK(it->second > 0);
49 it->second -= 1;
50 if (it->second == 0)
51 prerender_urls_.erase(it);
52 }
53
54 } // namespace prerender
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698