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
|
// 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.
// Describes a class that can represent the information displayed in a history
// view; that is, a list of visited pages. This object knows how to
// talk to the HistoryService to update its state.
#ifndef CHROME_BROWSER_HISTORY_MODEL_H__
#define CHROME_BROWSER_HISTORY_MODEL_H__
#include "chrome/browser/base_history_model.h"
#include "chrome/common/notification_service.h"
typedef BaseHistoryModelObserver HistoryModelObserver;
class HistoryModel : public BaseHistoryModel,
public NotificationObserver {
public:
HistoryModel(Profile* profile, const std::wstring& search_text);
virtual ~HistoryModel();
// BaseHistoryModel methods (see BaseHistoryModel for description).
virtual int GetItemCount();
virtual Time GetVisitTime(int index);
virtual const std::wstring& GetTitle(int index);
virtual const GURL& GetURL(int index);
virtual history::URLID GetURLID(int index);
virtual bool IsStarred(int index);
virtual const Snippet& GetSnippet(int index);
virtual void RemoveFromModel(int start, int length);
// 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 { return search_text_; }
// Change the starred state of a given index.
virtual void SetPageStarred(int index, bool state);
// To be called when the user wants to manually refresh this view.
virtual void Refresh();
// NotificationObserver implementation. If the type is NOTIFY_URLS_STARRED,
// the model is updated appropriately.
virtual void Observe(NotificationType type,
const NotificationSource& source,
const NotificationDetails& details);
private:
// Initiates a request for the current visit list.
void InitVisitRequest(int depth);
// Callback for visited page requests of the history system.
void VisitedPagesQueryComplete(HistoryService::Handle request_handle,
history::QueryResults* results);
// Sets the starred state of each instance of the given URL in the result set
// to the given value. Returns true if anything was updated.
bool UpdateStarredStateOfURL(const GURL& url, bool is_starred);
// The current search string.
std::wstring search_text_;
// Contents of the current query.
history::QueryResults results_;
// We lazily ask the BookmarkBarModel for whether a URL is starred. This
// enum gives the state of a particular entry.
enum StarState {
UNKNOWN = 0, // Indicates we haven't determined the state yet.
STARRED,
NOT_STARRED
};
// star_state_ has an entry for each element of results_ indicating whether
// the URL is starred.
scoped_array<StarState> star_state_;
// How many months back the current query has gone.
int search_depth_;
// The time that the current query was started.
Time search_start_;
DISALLOW_EVIL_CONSTRUCTORS(HistoryModel);
};
#endif // CHROME_BROWSER_HISTORY_MODEL_H__
|