| Index: components/reading_list/ios/reading_list_model.h
 | 
| diff --git a/components/reading_list/ios/reading_list_model.h b/components/reading_list/ios/reading_list_model.h
 | 
| deleted file mode 100644
 | 
| index 50d983fb47f0afab31ef079e5e13a823ec322dab..0000000000000000000000000000000000000000
 | 
| --- a/components/reading_list/ios/reading_list_model.h
 | 
| +++ /dev/null
 | 
| @@ -1,175 +0,0 @@
 | 
| -// 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 COMPONENTS_READING_LIST_IOS_READING_LIST_MODEL_H_
 | 
| -#define COMPONENTS_READING_LIST_IOS_READING_LIST_MODEL_H_
 | 
| -
 | 
| -#include <memory>
 | 
| -#include <string>
 | 
| -#include <vector>
 | 
| -
 | 
| -#include "base/callback.h"
 | 
| -#include "base/observer_list.h"
 | 
| -#include "base/threading/non_thread_safe.h"
 | 
| -#include "components/reading_list/ios/reading_list_entry.h"
 | 
| -#include "components/reading_list/ios/reading_list_model_observer.h"
 | 
| -
 | 
| -class GURL;
 | 
| -class ReadingListModel;
 | 
| -class ScopedReadingListBatchUpdate;
 | 
| -
 | 
| -namespace syncer {
 | 
| -class ModelTypeSyncBridge;
 | 
| -}
 | 
| -
 | 
| -// The reading list model contains two list of entries: one of unread urls, the
 | 
| -// other of read ones. This object should only be accessed from one thread
 | 
| -// (Usually the main thread). The observers callbacks are also sent on the main
 | 
| -// thread.
 | 
| -class ReadingListModel : public base::NonThreadSafe {
 | 
| - public:
 | 
| -  class ScopedReadingListBatchUpdate;
 | 
| -
 | 
| -  // Returns true if the model finished loading. Until this returns true the
 | 
| -  // reading list is not ready for use.
 | 
| -  virtual bool loaded() const = 0;
 | 
| -
 | 
| -  // Returns true if the model is performing batch updates right now.
 | 
| -  bool IsPerformingBatchUpdates() const;
 | 
| -
 | 
| -  // Returns the ModelTypeSyncBridge responsible for handling sync message.
 | 
| -  virtual syncer::ModelTypeSyncBridge* GetModelTypeSyncBridge() = 0;
 | 
| -
 | 
| -  // Tells model to prepare for batch updates.
 | 
| -  // This method is reentrant, i.e. several batch updates may take place at the
 | 
| -  // same time.
 | 
| -  // Returns a scoped batch update object that should be retained while the
 | 
| -  // batch update is performed. Deallocating this object will inform model that
 | 
| -  // the batch update has completed.
 | 
| -  std::unique_ptr<ScopedReadingListBatchUpdate> BeginBatchUpdates();
 | 
| -
 | 
| -  // Creates a batch token that will freeze the model while in scope.
 | 
| -  virtual std::unique_ptr<ScopedReadingListBatchUpdate> CreateBatchToken();
 | 
| -
 | 
| -  // Returns a vector of URLs in the model. The order of the URL is not
 | 
| -  // specified and can vary on successive calls.
 | 
| -  virtual const std::vector<GURL> Keys() const = 0;
 | 
| -
 | 
| -  // Returns the total number of entries in the model.
 | 
| -  virtual size_t size() const = 0;
 | 
| -
 | 
| -  // Returns the total number of unread entries in the model.
 | 
| -  virtual size_t unread_size() const = 0;
 | 
| -
 | 
| -  // Returns the total number of unseen entries in the model. Note: These
 | 
| -  // entries are also unread so unseen_size() <= unread_size().
 | 
| -  virtual size_t unseen_size() const = 0;
 | 
| -
 | 
| -  // Mark all unseen entries as unread.
 | 
| -  virtual void MarkAllSeen() = 0;
 | 
| -
 | 
| -  // Delete all the Reading List entries. Return true if entries where indeed
 | 
| -  // deleted.
 | 
| -  virtual bool DeleteAllEntries() = 0;
 | 
| -
 | 
| -  // Returns the flag about unseen entries on the device.
 | 
| -  // This flag is raised if some unseen items are added on this device.
 | 
| -  // The flag is reset if |ResetLocalUnseenFlag| is called or if all unseen
 | 
| -  // entries are removed.
 | 
| -  // This is a local flag and it can have different values on different devices,
 | 
| -  // even if they are synced.
 | 
| -  // (unseen_size() == 0 => GetLocalUnseenFlag() == false)
 | 
| -  virtual bool GetLocalUnseenFlag() const = 0;
 | 
| -
 | 
| -  // Set the unseen flag to false.
 | 
| -  virtual void ResetLocalUnseenFlag() = 0;
 | 
| -
 | 
| -  // Returns a specific entry. Returns null if the entry does not exist.
 | 
| -  virtual const ReadingListEntry* GetEntryByURL(const GURL& gurl) const = 0;
 | 
| -
 | 
| -  // Returns the first unread entry. If |distilled| is true, prioritize the
 | 
| -  // entries available offline.
 | 
| -  virtual const ReadingListEntry* GetFirstUnreadEntry(bool distilled) const = 0;
 | 
| -
 | 
| -  // Adds |url| at the top of the unread entries, and removes entries with the
 | 
| -  // same |url| from everywhere else if they exist. The entry title will be a
 | 
| -  // trimmed copy of |title|.
 | 
| -  // The addition may be asynchronous, and the data will be available only once
 | 
| -  // the observers are notified.
 | 
| -  virtual const ReadingListEntry& AddEntry(
 | 
| -      const GURL& url,
 | 
| -      const std::string& title,
 | 
| -      reading_list::EntrySource source) = 0;
 | 
| -
 | 
| -  // Removes an entry. The removal may be asynchronous, and not happen
 | 
| -  // immediately.
 | 
| -  virtual void RemoveEntryByURL(const GURL& url) = 0;
 | 
| -
 | 
| -  // If the |url| is in the reading list and entry(|url|).read != |read|, sets
 | 
| -  // the read state of the URL to read. This will also update the update time of
 | 
| -  // the entry.
 | 
| -  virtual void SetReadStatus(const GURL& url, bool read) = 0;
 | 
| -
 | 
| -  // Methods to mutate an entry. Will locate the relevant entry by URL. Does
 | 
| -  // nothing if the entry is not found.
 | 
| -  virtual void SetEntryTitle(const GURL& url, const std::string& title) = 0;
 | 
| -  virtual void SetEntryDistilledState(
 | 
| -      const GURL& url,
 | 
| -      ReadingListEntry::DistillationState state) = 0;
 | 
| -
 | 
| -  // Sets the Distilled info for the entry |url|. This method sets the
 | 
| -  // DistillationState of the entry to PROCESSED and sets the |distilled_path|
 | 
| -  // (path of the file on disk), the |distilled_url| (url of the page that
 | 
| -  // was distilled, the |distillation_size| (the size of the offline data) and
 | 
| -  // the |distillation_date| (date of distillation in microseconds since Jan 1st
 | 
| -  // 1970.
 | 
| -  virtual void SetEntryDistilledInfo(const GURL& url,
 | 
| -                                     const base::FilePath& distilled_path,
 | 
| -                                     const GURL& distilled_url,
 | 
| -                                     int64_t distilation_size,
 | 
| -                                     const base::Time& distilation_time) = 0;
 | 
| -
 | 
| -  // Observer registration methods. The model will remove all observers upon
 | 
| -  // destruction automatically.
 | 
| -  void AddObserver(ReadingListModelObserver* observer);
 | 
| -  void RemoveObserver(ReadingListModelObserver* observer);
 | 
| -
 | 
| -  // Helper class that is used to scope batch updates.
 | 
| -  class ScopedReadingListBatchUpdate {
 | 
| -   public:
 | 
| -    explicit ScopedReadingListBatchUpdate(ReadingListModel* model)
 | 
| -        : model_(model) {}
 | 
| -
 | 
| -    virtual ~ScopedReadingListBatchUpdate();
 | 
| -
 | 
| -   private:
 | 
| -    ReadingListModel* model_;
 | 
| -
 | 
| -    DISALLOW_COPY_AND_ASSIGN(ScopedReadingListBatchUpdate);
 | 
| -  };
 | 
| -
 | 
| - protected:
 | 
| -  ReadingListModel();
 | 
| -  virtual ~ReadingListModel();
 | 
| -
 | 
| -  // The observers.
 | 
| -  base::ObserverList<ReadingListModelObserver> observers_;
 | 
| -
 | 
| -  // Tells model that batch updates have completed. Called from
 | 
| -  // ReadingListBatchUpdateToken dtor.
 | 
| -  virtual void EndBatchUpdates();
 | 
| -
 | 
| -  // Called when model is entering batch update mode.
 | 
| -  virtual void EnteringBatchUpdates();
 | 
| -
 | 
| -  // Called when model is leaving batch update mode.
 | 
| -  virtual void LeavingBatchUpdates();
 | 
| -
 | 
| - private:
 | 
| -  unsigned int current_batch_updates_count_;
 | 
| -
 | 
| -  DISALLOW_COPY_AND_ASSIGN(ReadingListModel);
 | 
| -};
 | 
| -
 | 
| -#endif  // COMPONENTS_READING_LIST_IOS_READING_LIST_MODEL_H_
 | 
| 
 |