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

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

Issue 2587443002: predictors: Make speculative_prefetch_predictor work with PlzNavigate (Closed)
Patch Set: Updates after lizeb@ first review and rebase 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 "chrome/browser/sessions/session_tab_helper.h"
Benoit L 2016/12/20 13:20:49 nit: please move the header file inclusion to the
12 #include "components/sessions/core/session_id.h"
11 #include "url/gurl.h" 13 #include "url/gurl.h"
12 14
13 class Profile; 15 class Profile;
14 16
15 namespace content { 17 namespace content {
16 class WebContents; 18 class WebContents;
17 } 19 }
18 20
19 namespace predictors { 21 namespace predictors {
20 22
(...skipping 15 matching lines...) Expand all
36 enum class PrefetchOrigin { NAVIGATION, EXTERNAL }; 38 enum class PrefetchOrigin { NAVIGATION, EXTERNAL };
37 39
38 // Represents a single navigation for a render frame. 40 // Represents a single navigation for a render frame.
39 struct NavigationID { 41 struct NavigationID {
40 NavigationID(); 42 NavigationID();
41 explicit NavigationID(content::WebContents* web_contents); 43 explicit NavigationID(content::WebContents* web_contents);
42 NavigationID(content::WebContents* web_contents, 44 NavigationID(content::WebContents* web_contents,
43 const GURL& main_frame_url, 45 const GURL& main_frame_url,
44 const base::TimeTicks& creation_time); 46 const base::TimeTicks& creation_time);
45 NavigationID(const NavigationID& other); 47 NavigationID(const NavigationID& other);
48
46 bool operator<(const NavigationID& rhs) const; 49 bool operator<(const NavigationID& rhs) const;
47 bool operator==(const NavigationID& rhs) const; 50 bool operator==(const NavigationID& rhs) const;
48 51
49 bool IsSameRenderer(const NavigationID& other) const;
50
51 // Returns true iff the render_process_id_, render_frame_id_ and 52 // Returns true iff the render_process_id_, render_frame_id_ and
52 // frame_url_ has been set correctly. 53 // frame_url_ has been set correctly.
53 bool is_valid() const; 54 bool is_valid() const;
54 55
55 int render_process_id; 56 SessionID::id_type session_id;
56 int render_frame_id;
57 GURL main_frame_url; 57 GURL main_frame_url;
58 58
59 // NOTE: Even though we store the creation time here, it is not used during 59 // 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 60 // comparison of two NavigationIDs because it cannot always be determined
61 // correctly. 61 // correctly.
62 base::TimeTicks creation_time; 62 base::TimeTicks creation_time;
63 }; 63 };
64 64
65 // Represents the config for the resource prefetch prediction algorithm. 65 // Represents the config for the resource prefetch prediction algorithm.
66 struct ResourcePrefetchPredictorConfig { 66 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. 115 // Maximum number of prefetches that can be inflight for a single navigation.
116 size_t max_prefetches_inflight_per_navigation; 116 size_t max_prefetches_inflight_per_navigation;
117 // Maximum number of prefetches that can be inflight for a host for a single 117 // Maximum number of prefetches that can be inflight for a host for a single
118 // navigation. 118 // navigation.
119 size_t max_prefetches_inflight_per_host_per_navigation; 119 size_t max_prefetches_inflight_per_host_per_navigation;
120 }; 120 };
121 121
122 } // namespace predictors 122 } // namespace predictors
123 123
124 #endif // CHROME_BROWSER_PREDICTORS_RESOURCE_PREFETCH_COMMON_H_ 124 #endif // CHROME_BROWSER_PREDICTORS_RESOURCE_PREFETCH_COMMON_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698