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

Unified Diff: components/previews/core/previews_black_list_item.h

Issue 2480203002: ui: Cleanup class/struct forward declarations (Closed)
Patch Set: Sync CL to position 430550 Created 4 years, 1 month 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/core/previews_black_list_item.h
diff --git a/components/previews/core/previews_black_list_item.h b/components/previews/core/previews_black_list_item.h
index 462e61d1c4ade6782ada52f7035baef9dd35d5b2..22d8c442e8ac8aab767a29e7138ca3ebdbfae093 100644
--- a/components/previews/core/previews_black_list_item.h
+++ b/components/previews/core/previews_black_list_item.h
@@ -7,9 +7,9 @@
#include <stdint.h>
-#include <list>
#include <map>
#include <memory>
+#include <queue>
#include <string>
#include "base/callback.h"
@@ -44,15 +44,34 @@ class PreviewsBlackListItem {
return most_recent_opt_out_time_;
}
+ size_t OptOutRecordsSizeForTesting() const;
+
private:
// A previews navigation to this host is represented by time and whether the
// navigation was an opt out.
- struct OptOutRecord {
+ class OptOutRecord {
+ public:
OptOutRecord(base::Time entry_time, bool opt_out);
- ~OptOutRecord() {}
- const base::Time
- entry_time; // The time that the opt out state was determined.
- const bool opt_out; // Whether the user opt out of the preview.
+ ~OptOutRecord();
+ OptOutRecord(OptOutRecord&&);
+ OptOutRecord& operator=(OptOutRecord&&);
+
+ // Used to determine eviction priority.
+ bool operator<(const OptOutRecord& other) const;
+
+ // The time that the opt out state was determined.
+ base::Time entry_time() const { return entry_time_; }
+
+ // Whether the user opted out of the preview.
+ bool opt_out() const { return opt_out_; }
+
+ private:
+ // The time that the opt out state was determined.
+ base::Time entry_time_;
+ // Whether the user opted out of the preview.
+ bool opt_out_;
+
+ DISALLOW_COPY_AND_ASSIGN(OptOutRecord);
};
// The number of entries to store to determine preview eligibility.
@@ -63,8 +82,9 @@ class PreviewsBlackListItem {
const base::TimeDelta max_black_list_duration_;
// The |max_stored_history_length_| most recent previews navigation. Is
- // maintained as a list sorted by entry_time (earliest to latest).
- std::list<OptOutRecord> opt_out_records_;
+ // maintained as a priority queue that has high priority for items that should
+ // be evicted (i.e., they are old).
+ std::priority_queue<OptOutRecord> opt_out_records_;
// Time of the most recent opt out.
base::Optional<base::Time> most_recent_opt_out_time_;
« no previous file with comments | « components/previews/core/previews_black_list.cc ('k') | components/previews/core/previews_black_list_item.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698