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

Side by Side Diff: components/reading_list/ios/reading_list_model_impl.h

Issue 2525663002: Refactor Reading List Model to use URL as key. (Closed)
Patch Set: feedback 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 2016 The Chromium Authors. All rights reserved. 1 // Copyright 2016 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 COMPONENTS_READING_LIST_IOS_READING_LIST_MODEL_IMPL_H_ 5 #ifndef COMPONENTS_READING_LIST_IOS_READING_LIST_MODEL_IMPL_H_
6 #define COMPONENTS_READING_LIST_IOS_READING_LIST_MODEL_IMPL_H_ 6 #define COMPONENTS_READING_LIST_IOS_READING_LIST_MODEL_IMPL_H_
7 7
8 #include <memory> 8 #include <memory>
9 #include <unordered_map>
jif-google 2016/11/28 16:28:21 This is not needed.
9 10
10 #include "components/keyed_service/core/keyed_service.h" 11 #include "components/keyed_service/core/keyed_service.h"
11 #include "components/reading_list/ios/reading_list_entry.h" 12 #include "components/reading_list/ios/reading_list_entry.h"
12 #include "components/reading_list/ios/reading_list_model.h" 13 #include "components/reading_list/ios/reading_list_model.h"
13 #include "components/reading_list/ios/reading_list_model_storage.h" 14 #include "components/reading_list/ios/reading_list_model_storage.h"
14 #include "components/reading_list/ios/reading_list_store_delegate.h" 15 #include "components/reading_list/ios/reading_list_store_delegate.h"
15 16
16 class PrefService; 17 class PrefService;
17 18
18 // Concrete implementation of a reading list model using in memory lists. 19 // Concrete implementation of a reading list model using in memory lists.
19 class ReadingListModelImpl : public ReadingListModel, 20 class ReadingListModelImpl : public ReadingListModel,
20 public ReadingListStoreDelegate, 21 public ReadingListStoreDelegate,
21 public KeyedService { 22 public KeyedService {
22 public: 23 public:
23 // Initialize a ReadingListModelImpl to load and save data in 24 // Initialize a ReadingListModelImpl to load and save data in
24 // |persistence_layer|. 25 // |persistence_layer|.
25 ReadingListModelImpl(std::unique_ptr<ReadingListModelStorage> storage_layer, 26 ReadingListModelImpl(std::unique_ptr<ReadingListModelStorage> storage_layer,
26 PrefService* pref_service); 27 PrefService* pref_service);
27 28
28 // Initialize a ReadingListModelImpl without persistence. Data will not be 29 // Initialize a ReadingListModelImpl without persistence. Data will not be
29 // persistent across sessions. 30 // persistent across sessions.
30 ReadingListModelImpl(); 31 ReadingListModelImpl();
31 32
32 syncer::ModelTypeSyncBridge* GetModelTypeSyncBridge() override; 33 syncer::ModelTypeSyncBridge* GetModelTypeSyncBridge() override;
33 34
34 ~ReadingListModelImpl() override; 35 ~ReadingListModelImpl() override;
35 36
36 void StoreLoaded(std::unique_ptr<ReadingListEntries> unread, 37 void StoreLoaded(std::unique_ptr<ReadingListEntries> entries) override;
37 std::unique_ptr<ReadingListEntries> read) override;
38 38
39 // KeyedService implementation. 39 // KeyedService implementation.
40 void Shutdown() override; 40 void Shutdown() override;
41 41
42 // ReadingListModel implementation. 42 // ReadingListModel implementation.
43 bool loaded() const override; 43 bool loaded() const override;
44 44
45 size_t size() const override;
45 size_t unread_size() const override; 46 size_t unread_size() const override;
46 size_t read_size() const override; 47 size_t read_size() const override;
47 48
48 bool HasUnseenEntries() const override; 49 bool HasUnseenEntries() const override;
49 void ResetUnseenEntries() override; 50 void ResetUnseenEntries() override;
50 51
52 const ReadingListEntries::iterator begin() const override;
53 const ReadingListEntries::iterator end() const override;
54
55 const ReadingListEntry* GetEntryByURL(const GURL& gurl) const override;
51 const ReadingListEntry& GetUnreadEntryAtIndex(size_t index) const override; 56 const ReadingListEntry& GetUnreadEntryAtIndex(size_t index) const override;
52 const ReadingListEntry& GetReadEntryAtIndex(size_t index) const override; 57 const ReadingListEntry& GetReadEntryAtIndex(size_t index) const override;
53 58 void MarkReadByURL(const GURL& url) override;
54 const ReadingListEntry* GetEntryFromURL(const GURL& gurl, 59 void MarkUnreadByURL(const GURL& url) override;
55 bool* read) const override;
56
57 bool CallbackEntryURL(
58 const GURL& url,
59 base::Callback<void(const ReadingListEntry&)> callback) const override;
60 60
61 void RemoveEntryByURL(const GURL& url) override; 61 void RemoveEntryByURL(const GURL& url) override;
62 62
63 const ReadingListEntry& AddEntry(const GURL& url, 63 const ReadingListEntry& AddEntry(const GURL& url,
64 const std::string& title) override; 64 const std::string& title) override;
65 65
66 void MarkReadByURL(const GURL& url) override; 66 void SetReadStatus(const GURL& url, bool read) override;
67 void MarkUnreadByURL(const GURL& url) override;
68 67
69 void SetEntryTitle(const GURL& url, const std::string& title) override; 68 void SetEntryTitle(const GURL& url, const std::string& title) override;
70 void SetEntryDistilledPath(const GURL& url, 69 void SetEntryDistilledPath(const GURL& url,
71 const base::FilePath& distilled_path) override; 70 const base::FilePath& distilled_path) override;
72 void SetEntryDistilledState( 71 void SetEntryDistilledState(
73 const GURL& url, 72 const GURL& url,
74 ReadingListEntry::DistillationState state) override; 73 ReadingListEntry::DistillationState state) override;
75 74
76 void SyncAddEntry(std::unique_ptr<ReadingListEntry> entry, 75 void SyncAddEntry(std::unique_ptr<ReadingListEntry> entry) override;
77 bool read) override; 76 ReadingListEntry* SyncMergeEntry(
78 ReadingListEntry* SyncMergeEntry(std::unique_ptr<ReadingListEntry> entry, 77 std::unique_ptr<ReadingListEntry> entry) override;
79 bool read) override;
80 void SyncRemoveEntry(const GURL& url) override; 78 void SyncRemoveEntry(const GURL& url) override;
81 79
82 std::unique_ptr<ReadingListModel::ScopedReadingListBatchUpdate> 80 std::unique_ptr<ReadingListModel::ScopedReadingListBatchUpdate>
83 CreateBatchToken() override; 81 CreateBatchToken() override;
84 82
85 // Helper class that is used to scope batch updates. 83 // Helper class that is used to scope batch updates.
86 class ScopedReadingListBatchUpdate 84 class ScopedReadingListBatchUpdate
87 : public ReadingListModel::ScopedReadingListBatchUpdate { 85 : public ReadingListModel::ScopedReadingListBatchUpdate {
88 public: 86 public:
89 explicit ScopedReadingListBatchUpdate(ReadingListModelImpl* model); 87 explicit ScopedReadingListBatchUpdate(ReadingListModelImpl* model);
90 88
91 ~ScopedReadingListBatchUpdate() override; 89 ~ScopedReadingListBatchUpdate() override;
92 90
93 private: 91 private:
94 std::unique_ptr<ReadingListModelStorage::ScopedBatchUpdate> storage_token_; 92 std::unique_ptr<ReadingListModelStorage::ScopedBatchUpdate> storage_token_;
95 93
96 DISALLOW_COPY_AND_ASSIGN(ScopedReadingListBatchUpdate); 94 DISALLOW_COPY_AND_ASSIGN(ScopedReadingListBatchUpdate);
97 }; 95 };
98 96
99 protected: 97 protected:
100 void EnteringBatchUpdates() override; 98 void EnteringBatchUpdates() override;
101 void LeavingBatchUpdates() override; 99 void LeavingBatchUpdates() override;
102 100
103 private: 101 private:
104 // Sets/Loads the pref flag that indicate if some entries have never been seen 102 // Sets/Loads the pref flag that indicate if some entries have never been seen
105 // since being added to the store. 103 // since being added to the store.
106 void SetPersistentHasUnseen(bool has_unseen); 104 void SetPersistentHasUnseen(bool has_unseen);
107 bool GetPersistentHasUnseen(); 105 bool GetPersistentHasUnseen();
108 106
109 // Returns a mutable pointer to the entry with URL |gurl|. Return nullptr if 107 // Returns a mutable pointer to the entry with URL |url|. Return nullptr if
110 // no entry is found. If an entry is found, |read| is set to the read status 108 // no entry is found.
111 // of the entry. 109 ReadingListEntry* GetMutableEntryFromURL(const GURL& url) const;
112 ReadingListEntry* GetMutableEntryFromURL(const GURL& gurl, bool* read) const;
113
114 // Sorts the entries in |read_| and |unread_| according to their |UpdateTime|.
115 void SortEntries();
116 110
117 // Returns the |storage_layer_| of the model. 111 // Returns the |storage_layer_| of the model.
118 ReadingListModelStorage* StorageLayer(); 112 ReadingListModelStorage* StorageLayer();
119 113
120 // Remove |entry| from the |entries| vector and calls the Move notifications
121 // on observers.
122 void MoveEntryFrom(ReadingListEntries* entries,
123 const ReadingListEntry& entry,
124 bool read);
125
126 // Remove entry |url| and propagate to store if |from_sync| is false. 114 // Remove entry |url| and propagate to store if |from_sync| is false.
127 void RemoveEntryByURLImpl(const GURL& url, bool from_sync); 115 void RemoveEntryByURLImpl(const GURL& url, bool from_sync);
128 116
129 std::unique_ptr<ReadingListEntries> unread_; 117 void RebuildIndex() const;
130 std::unique_ptr<ReadingListEntries> read_; 118
119 std::unique_ptr<ReadingListEntries> entries_;
120 size_t unread_entry_count_;
121 size_t read_entry_count_;
122
123 // TODO(crbug.com/664924): Remove temporary cache and move it to
124 // ReadingListViewController.
125 struct Cache {
126 Cache();
127 ~Cache();
128 std::vector<GURL> read_entries;
129 std::vector<GURL> unread_entries;
130 bool dirty;
131 };
132 std::unique_ptr<struct Cache> cache_;
133
131 std::unique_ptr<ReadingListModelStorage> storage_layer_; 134 std::unique_ptr<ReadingListModelStorage> storage_layer_;
132 PrefService* pref_service_; 135 PrefService* pref_service_;
133 bool has_unseen_; 136 bool has_unseen_;
134 bool loaded_; 137 bool loaded_;
135 base::WeakPtrFactory<ReadingListModelImpl> weak_ptr_factory_; 138 base::WeakPtrFactory<ReadingListModelImpl> weak_ptr_factory_;
136 DISALLOW_COPY_AND_ASSIGN(ReadingListModelImpl); 139 DISALLOW_COPY_AND_ASSIGN(ReadingListModelImpl);
137 }; 140 };
138 141
139 #endif // COMPONENTS_READING_LIST_IOS_READING_LIST_MODEL_IMPL_H_ 142 #endif // COMPONENTS_READING_LIST_IOS_READING_LIST_MODEL_IMPL_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698