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

Unified Diff: components/previews/previews_data_savings.h

Issue 2257533003: Adding a previews object, PreviewsDataSavings (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: updating dependent cl Created 4 years, 4 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 side-by-side diff with in-line comments
Download patch
Index: components/previews/previews_data_savings.h
diff --git a/components/previews/previews_data_savings.h b/components/previews/previews_data_savings.h
new file mode 100644
index 0000000000000000000000000000000000000000..f28d6ccb5661cd7ddedfe8a3229158086671265d
--- /dev/null
+++ b/components/previews/previews_data_savings.h
@@ -0,0 +1,58 @@
+// 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_PREVIEWS_PREVIEWS_DATA_SAVINGS_H_
+#define CHROME_BROWSER_PREVIEWS_PREVIEWS_DATA_SAVINGS_H_
+
+#include <stdint.h>
+
+#include <string>
+
+#include "base/macros.h"
+#include "base/threading/thread_checker.h"
+
+namespace data_reduction_proxy {
+class DataSavingsRecorder;
+class DataSaverStatus;
+}
+
+namespace previews {
+
+// Provides an interface for previews/ to record data savings and report is as
bengr 2016/08/25 23:04:19 This class shouldn't care how it is going to be us
RyanSturm 2016/08/26 17:47:40 Done.
+// part of the data savings seen by data saver users.
+class PreviewsDataSavings {
Not at Google. Contact bengr 2016/08/25 19:24:48 Would it make sense for PreviewsDataSavings to be
RyanSturm 2016/08/25 20:22:45 DataReductionProxy shouldn't know anything about p
Not at Google. Contact bengr 2016/08/26 00:36:10 How will this class be initialized and hooked up?
RyanSturm 2016/08/26 17:47:39 Still not finalized; here is a CL with a possibili
+ public:
+ PreviewsDataSavings(
bengr 2016/08/25 23:04:19 This needs a comment.
RyanSturm 2016/08/26 17:47:40 Done.
+ data_reduction_proxy::DataSavingsRecorder* data_savings_recorder,
+ data_reduction_proxy::DataSaverStatus* data_reduction_proxy_settings);
+ ~PreviewsDataSavings();
+
+ // Records the amount of data used by that preview, and the amount of data
bengr 2016/08/25 23:04:19 that -> the without -> if the original page had be
RyanSturm 2016/08/26 17:47:39 Done.
+ // that would have been used without the preview. |is_update| allows
+ // adjustment to previosuly recorded data (all URLRequest data_used is
bengr 2016/08/25 23:04:19 previously Also, what does "adjustment" mean in t
RyanSturm 2016/08/26 17:47:40 It's not, done.
+ // tracked). |host| is the host name to attribute the data savings to (e.g.
bengr 2016/08/25 23:04:19 Is host the right term? FQDM might be better.
RyanSturm 2016/08/26 17:47:39 Done.
+ // codereview.chromium.org).
+ void RecordDataSavings(const std::string& host,
+ int64_t data_used,
+ int64_t original_size);
+
+ private:
+ // Owned by DataReductionProxyService, which will outlive the WebContents
bengr 2016/08/25 23:04:19 This interface shouldn't know anything about its e
RyanSturm 2016/08/26 17:47:40 Done.
+ // that ultimately owns |this|.
+ // Provides a method to record data savings.
+ data_reduction_proxy::DataSavingsRecorder* data_savings_recorder_;
+ // Owned by DataReductionProxyService, which will outlive the WebContents
bengr 2016/08/25 23:04:19 Here too.
RyanSturm 2016/08/26 17:47:39 Done.
+ // that ultimately owns |this|.
+ // Provides a method to determine if data saver is enabled.
+ data_reduction_proxy::DataSaverStatus* data_saver_status_;
bengr 2016/08/25 23:04:19 It might be better to store a callback instead of
RyanSturm 2016/08/26 17:47:40 See other comment.
+
+ // Enforce usage on the UI thread.
+ base::ThreadChecker thread_checker_;
+
+ DISALLOW_COPY_AND_ASSIGN(PreviewsDataSavings);
+};
+
+} // namespace previews
+
+#endif // CHROME_BROWSER_PREVIEWS_PREVIEWS_DATA_SAVINGS_H_

Powered by Google App Engine
This is Rietveld 408576698