summaryrefslogtreecommitdiffstats
path: root/chrome/browser/base_history_model.h
blob: 6a0805a0a4f17e4df39813684394b55cff79f4bd (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
// Copyright 2008, Google Inc.
// All rights reserved.
//
// Redistribution and use in source and binary forms, with or without
// modification, are permitted provided that the following conditions are
// met:
//
//    * Redistributions of source code must retain the above copyright
// notice, this list of conditions and the following disclaimer.
//    * Redistributions in binary form must reproduce the above
// copyright notice, this list of conditions and the following disclaimer
// in the documentation and/or other materials provided with the
// distribution.
//    * Neither the name of Google Inc. nor the names of its
// contributors may be used to endorse or promote products derived from
// this software without specific prior written permission.
//
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.

// Base class used by history view. BaseHistoryModel provides support for
// fetching thumbnails and favicons, but not the actual contents that are
// displayed.

#ifndef CHROME_BROWSER_BASE_HISTORY_MODEL_H__
#define CHROME_BROWSER_BASE_HISTORY_MODEL_H__

#include "base/basictypes.h"
#include "base/time.h"
#include "chrome/browser/history/history.h"
#include "chrome/common/mru_cache.h"
#include "SkBitmap.h"

class Profile;

// Defines functions that allow a view associated with this model to
// learn that it should relayout/paint itself.
class BaseHistoryModelObserver {
 public:
  // Called when the data in the model has changed.
  // |result_set_changed| is true when the model item counts have changed,
  // false when the change is just item metadata (like thumbnails or
   // starredness).
  virtual void ModelChanged(bool result_set_changed) = 0;

  // Called when a long operation has begun, to allow the observer to show
  // that work is pending.
  virtual void ModelBeginWork() = 0;

  // Called when a long operation has completed.
  virtual void ModelEndWork() = 0;
};

class BaseHistoryModel {
 public:
  explicit BaseHistoryModel(Profile* profile);
  virtual ~BaseHistoryModel();

  // The observer, notified of changes to the model or when processing
  // begins/ends.
  void SetObserver(BaseHistoryModelObserver* observer);
  BaseHistoryModelObserver* GetObserver() const;

  // Returns the number of history items currently in the model.
  virtual int GetItemCount() = 0;

  // Returns the time of the visit with the given index.
  virtual Time GetVisitTime(int index) = 0;

  // Returns the title at the specified index.
  virtual const std::wstring& GetTitle(int index) = 0;

  // Returns the URL at the specified index.
  virtual const GURL& GetURL(int index) = 0;

  // Returns the id of the URL at the specified index.
  virtual history::URLID GetURLID(int index) = 0;

  // Returns true if the page at the specified index is starred.
  virtual bool IsStarred(int index) = 0;

  // Returns true if the entries are search results (this affects the UI shown).
  virtual bool IsSearchResults() { return is_search_results_; }

  // Returns the snippet at the specified index.
  virtual const Snippet& GetSnippet(int index) = 0;

  // Returns the favicon or thumbnail for the specified page. If the image is
  // not available, NULL is returned. If the image has NOT been loaded, it is
  // loaded and the observer is called back when done loading.
  SkBitmap* GetThumbnail(int index);
  SkBitmap* GetFavicon(int index);

  // Sets the new value of the search text, and requeries if the new value
  // is different from the previous value.
  virtual void SetSearchText(const std::wstring& search_text) { }

  // Returns the search text.
  virtual const std::wstring& GetSearchText() const = 0;

  // Change the starred state of a given index.
  virtual void SetPageStarred(int index, bool state) = 0;

  // The following methods are only invoked by HistoryView if the HistoryView
  // is configured to show bookmark controls.

  // Returns true if the item is shown on the bookmark bar.
  virtual bool IsOnBookmarkBar(int index) { return false; }

  // Returns the path of the item on the bookmark bar. This may return the
  // empty string.
  virtual std::wstring GetBookmarkBarPath(int index) { return std::wstring(); }

  // Edits the specified entry. This is intended for bookmarks where the user
  // can edit various properties of the bookmark.
  virtual void Edit(int index) {}

  // Removes the specified entry.
  virtual void Remove(int index) {}

  // Removes the specified range from the model. This should NOT update the
  // backend, rather it should just update the model and notify listeners
  // appropriately. This need only be implemented if you turn on delete controls
  // in the hosting HistoryView.
  virtual void RemoveFromModel(int start, int length) { NOTREACHED(); }

  // Reloads the model.
  virtual void Refresh() = 0;

  Profile* profile() const { return profile_; }

  // Number of months history requests should go back for.
  static const int kHistoryScopeMonths;

 protected:
  // Invoke when you're about to schedule a request on the history service. If
  // no requests have been made, the observer is notified of ModelBeginWork.
  void AboutToScheduleRequest();

  // Invoke from a callback from the history service. If no requests are pending
  // on the history service the observer is notified of ModelEndWork.
  void RequestCompleted();

#ifndef NDEBUG
  // For debugging, meant to be wrapped in a DCHECK.
  bool IsValidIndex(int index) {
    return (index >= 0 && index < GetItemCount());
  }
#endif

  // The user profile associated with the page that this model feeds.
  Profile* profile_;

  // For history requests. This is used when requesting favicons and
  // thumbnails, subclasses may also use this.
  CancelableRequestConsumerT<history::URLID, 0> cancelable_consumer_;

  // Notified of changes to the content, typically HistoryView.
  BaseHistoryModelObserver* observer_;

  // Whether the last returned result was a set of search results.
  bool is_search_results_;

 private:
  // Enum of the types of image we cache. Used by GetImage.
  enum ImageType {
    THUMBNAIL,
    FAVICON
  };

  typedef MRUCache<history::URLID, SkBitmap> CacheType;

  // Returns the image at the specified index. If the image has not been loaded
  // it is loaded.
  SkBitmap* GetImage(ImageType type, int index);

  // Called when a request for the thumbnail data is complete. Updates the
  // thumnails_ cache and notifies the observer (assuming the image is valid).
  void OnThumbnailDataAvailable(
      HistoryService::Handle request_handle,
      scoped_refptr<RefCountedBytes> data);

  // Callback when a favicon is available. Updates the favicons_ cache and
  // notifies the observer (assuming we can extract a valid image).
  void OnFaviconDataAvailable(
      HistoryService::Handle handle,
      bool know_favicon,
      scoped_refptr<RefCountedBytes> data,
      bool expired,
      GURL icon_url);

  // Keeps track of thumbnails for pages
  CacheType thumbnails_;

  // Keeps track of favicons for pages
  CacheType favicons_;

  DISALLOW_EVIL_CONSTRUCTORS(BaseHistoryModel);
};

#endif  // CHROME_BROWSER_BASE_HISTORY_MODEL_H__