Index: chrome/browser/data_use_measurement/chrome_data_use_ascriber.h |
diff --git a/chrome/browser/data_use_measurement/chrome_data_use_ascriber.h b/chrome/browser/data_use_measurement/chrome_data_use_ascriber.h |
new file mode 100644 |
index 0000000000000000000000000000000000000000..339b85c9e3cea3ce7a0c9da4e6585d92880a619c |
--- /dev/null |
+++ b/chrome/browser/data_use_measurement/chrome_data_use_ascriber.h |
@@ -0,0 +1,83 @@ |
+// Copyright 2016 The Chromium Authors. All rights reserved. |
+// Use of this source code is governed by a BSD-style license that can be |
+// found in the LICENSE file. |
+ |
+#ifndef CHROME_BROWSER_DATA_USE_MEASUREMENT_CHROME_DATA_USE_ASCRIBER_H_ |
+#define CHROME_BROWSER_DATA_USE_MEASUREMENT_CHROME_DATA_USE_ASCRIBER_H_ |
+ |
+#include "base/macros.h" |
+#include "components/data_use_measurement/core/data_use_ascriber.h" |
+#include "net/base/layered_network_delegate.h" |
Lei Zhang
2016/09/08 22:04:42
What's this for?
Not at Google. Contact bengr
2016/09/09 18:37:16
Done.
|
+#include "url/gurl.h" |
+ |
+namespace content { |
+class NavigationHandle; |
+class RenderFrameHost; |
+} |
+ |
+namespace data_use_measurement { |
Lei Zhang
2016/09/08 22:04:42
nit: blank line after when it's not fwrd decls.
Not at Google. Contact bengr
2016/09/09 18:37:16
Done.
|
+// Browser implementation of |DataUseAscriber|. Maintains a list of |
Lei Zhang
2016/09/08 22:04:42
|variable_name|, Classes are written normally.
Not at Google. Contact bengr
2016/09/09 18:37:16
Done.
|
+// |DataUseRecorder| instances, one for each source of data, such as a page |
+// load. |
+// |
+// A page includes all resources loaded in response to a main page navigation. |
+// The scope of a page load ends either when the tab is closed or a new page |
+// load is initiated by clicking on a link, entering a new URL, window location |
+// change, etc |
Lei Zhang
2016/09/08 22:04:42
End sentences with periods.
Not at Google. Contact bengr
2016/09/09 18:37:16
Done.
|
+// |
+// For URLRequests initiated outside the context of a page load, such as |
+// Service Workers, Chrome Services, etc, a new instance of |DataUseRecorder| |
+// will be created for each |URLRequest|. |
+// |
+// Each page load will be associated with an instance of |DataUseRecorder|. |
+// Each URLRequest initiated in the context of a page load will be mapped to |
+// the |DataUseRecorder| instance for page load. |
+// |
+// This class lives entirely on the IO thread. It maintains a copy of frame and |
+// navigation information on the IO thread. |
+class ChromeDataUseAscriber : public DataUseAscriber { |
+ public: |
+ ChromeDataUseAscriber(); |
+ |
+ ~ChromeDataUseAscriber() override; |
+ |
+ // Chrome override of |GetDataUseRecorder()|. |
Lei Zhang
2016/09/08 22:04:42
This is not helpful. Just:
// DataUseAscriber:
[A
Not at Google. Contact bengr
2016/09/09 18:37:16
Done.
|
+ DataUseRecorder* GetDataUseRecorder(const net::URLRequest* request) override; |
+ |
+ // Must be called on the IO thread when a render frame host is created. |
Lei Zhang
2016/09/08 22:04:42
You can probably omit the "Must be called on the I
Not at Google. Contact bengr
2016/09/09 18:37:16
Done.
|
+ void RenderFrameCreated(int render_process_id, |
+ int render_frame_id, |
+ int parent_render_process_id, |
+ int parent_render_frame_id); |
+ |
+ // Must be called on the IO thread when a render frame host is deleted. |
+ void RenderFrameDeleted(int render_process_id, |
+ int render_frame_id, |
+ int parent_render_process_id, |
+ int parent_render_frame_id); |
+ |
+ // Must be called on the IO thread when a main frame navigation is started. |
+ void DidStartMainFrameNavigation(GURL gurl, |
Lei Zhang
2016/09/08 22:04:42
Pass by const-ref, here and below?
Not at Google. Contact bengr
2016/09/09 18:37:16
Comes from a different thread, so cannot use ref.
|
+ int render_process_id, |
+ int render_frame_id, |
+ void* navigation_handle); |
+ |
+ // Must be called on the IO thread when a main frame navigation is completed. |
+ void DidFinishMainFrameNavigation(GURL gurl, |
+ int render_process_id, |
+ int render_frame_id, |
+ bool is_same_page_navigation, |
+ void* navigation_handle); |
+ |
+ // Must be called on the IO thread when a main frame navigation is redirected. |
+ void DidRedirectMainFrameNavigation(GURL gurl, |
+ int render_process_id, |
+ int render_frame_id, |
+ void* navigation_handle); |
+ |
+ DISALLOW_COPY_AND_ASSIGN(ChromeDataUseAscriber); |
Lei Zhang
2016/09/08 22:04:42
DISALLOW_COPY_AND_ASSIGN() does no good if it's pu
Not at Google. Contact bengr
2016/09/09 18:37:16
Done.
|
+}; |
+ |
+} // namespace data_use_measurement |
+ |
+#endif // CHROME_BROWSER_DATA_USE_MEASUREMENT_CHROME_DATA_USE_ASCRIBER_H_ |