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

Side by Side Diff: chrome/browser/predictors/resource_prefetch_common.h

Issue 2587443002: predictors: Make speculative_prefetch_predictor work with PlzNavigate (Closed)
Patch Set: Modified after alexilin@ review Created 4 years 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
OLDNEW
1 // Copyright 2014 The Chromium Authors. All rights reserved. 1 // Copyright 2014 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_BROWSER_PREDICTORS_RESOURCE_PREFETCH_COMMON_H_ 5 #ifndef CHROME_BROWSER_PREDICTORS_RESOURCE_PREFETCH_COMMON_H_
6 #define CHROME_BROWSER_PREDICTORS_RESOURCE_PREFETCH_COMMON_H_ 6 #define CHROME_BROWSER_PREDICTORS_RESOURCE_PREFETCH_COMMON_H_
7 7
8 #include <stddef.h> 8 #include <stddef.h>
9 9
10 #include "base/time/time.h" 10 #include "base/time/time.h"
11 #include "components/sessions/core/session_id.h"
11 #include "url/gurl.h" 12 #include "url/gurl.h"
12 13
13 class Profile; 14 class Profile;
14 15
15 namespace content { 16 namespace content {
16 class WebContents; 17 class WebContents;
17 } 18 }
18 19
19 namespace predictors { 20 namespace predictors {
20 21
(...skipping 15 matching lines...) Expand all
36 enum class PrefetchOrigin { NAVIGATION, EXTERNAL }; 37 enum class PrefetchOrigin { NAVIGATION, EXTERNAL };
37 38
38 // Represents a single navigation for a render frame. 39 // Represents a single navigation for a render frame.
39 struct NavigationID { 40 struct NavigationID {
40 NavigationID(); 41 NavigationID();
41 explicit NavigationID(content::WebContents* web_contents); 42 explicit NavigationID(content::WebContents* web_contents);
42 NavigationID(content::WebContents* web_contents, 43 NavigationID(content::WebContents* web_contents,
43 const GURL& main_frame_url, 44 const GURL& main_frame_url,
44 const base::TimeTicks& creation_time); 45 const base::TimeTicks& creation_time);
45 NavigationID(const NavigationID& other); 46 NavigationID(const NavigationID& other);
47
46 bool operator<(const NavigationID& rhs) const; 48 bool operator<(const NavigationID& rhs) const;
47 bool operator==(const NavigationID& rhs) const; 49 bool operator==(const NavigationID& rhs) const;
48 50
49 bool IsSameRenderer(const NavigationID& other) const;
50
51 // Returns true iff the render_process_id_, render_frame_id_ and 51 // Returns true iff the render_process_id_, render_frame_id_ and
52 // frame_url_ has been set correctly. 52 // frame_url_ has been set correctly.
clamy 2016/12/22 15:52:41 This comment needs to be updated since render_proc
ahemery 2016/12/22 17:12:26 Done.
53 bool is_valid() const; 53 bool is_valid() const;
54 54
55 int render_process_id; 55 SessionID::id_type tab_id;
clamy 2016/12/22 15:52:41 How do you deal with the two concurrent navigation
Benoit L 2016/12/22 16:04:10 Per offline discussion: - The NavigationID matches
56 int render_frame_id;
57 GURL main_frame_url; 56 GURL main_frame_url;
58 57
59 // NOTE: Even though we store the creation time here, it is not used during 58 // NOTE: Even though we store the creation time here, it is not used during
60 // comparison of two NavigationIDs because it cannot always be determined 59 // comparison of two NavigationIDs because it cannot always be determined
61 // correctly. 60 // correctly.
62 base::TimeTicks creation_time; 61 base::TimeTicks creation_time;
63 }; 62 };
64 63
65 // Represents the config for the resource prefetch prediction algorithm. 64 // Represents the config for the resource prefetch prediction algorithm.
66 struct ResourcePrefetchPredictorConfig { 65 struct ResourcePrefetchPredictorConfig {
(...skipping 48 matching lines...) Expand 10 before | Expand all | Expand 10 after
115 // Maximum number of prefetches that can be inflight for a single navigation. 114 // Maximum number of prefetches that can be inflight for a single navigation.
116 size_t max_prefetches_inflight_per_navigation; 115 size_t max_prefetches_inflight_per_navigation;
117 // Maximum number of prefetches that can be inflight for a host for a single 116 // Maximum number of prefetches that can be inflight for a host for a single
118 // navigation. 117 // navigation.
119 size_t max_prefetches_inflight_per_host_per_navigation; 118 size_t max_prefetches_inflight_per_host_per_navigation;
120 }; 119 };
121 120
122 } // namespace predictors 121 } // namespace predictors
123 122
124 #endif // CHROME_BROWSER_PREDICTORS_RESOURCE_PREFETCH_COMMON_H_ 123 #endif // CHROME_BROWSER_PREDICTORS_RESOURCE_PREFETCH_COMMON_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698