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
|
// Copyright (c) 2006-2008 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.
// Data structures for communication between the history service on the main
// thread and the backend on the history thread.
#ifndef CHROME_BROWSER_HISTORY_HISTORY_MARSHALING_H__
#define CHROME_BROWSER_HISTORY_HISTORY_MARSHALING_H__
#include "base/scoped_vector.h"
#include "chrome/browser/cancelable_request.h"
#include "chrome/browser/history/history.h"
#include "chrome/browser/history/page_usage_data.h"
namespace history {
// Navigation -----------------------------------------------------------------
// Marshalling structure for AddPage.
class HistoryAddPageArgs : public base::RefCounted<HistoryAddPageArgs> {
public:
HistoryAddPageArgs(const GURL& arg_url,
base::Time arg_time,
const void* arg_id_scope,
int32 arg_page_id,
const GURL& arg_referrer,
const HistoryService::RedirectList& arg_redirects,
PageTransition::Type arg_transition)
: url(arg_url),
time(arg_time),
id_scope(arg_id_scope),
page_id(arg_page_id),
referrer(arg_referrer),
redirects(arg_redirects),
transition(arg_transition) {
}
GURL url;
base::Time time;
const void* id_scope;
int32 page_id;
GURL referrer;
HistoryService::RedirectList redirects;
PageTransition::Type transition;
private:
DISALLOW_EVIL_CONSTRUCTORS(HistoryAddPageArgs);
};
// Querying -------------------------------------------------------------------
typedef CancelableRequest1<HistoryService::QueryURLCallback,
Tuple2<URLRow, VisitVector> >
QueryURLRequest;
typedef CancelableRequest1<HistoryService::QueryHistoryCallback,
QueryResults>
QueryHistoryRequest;
typedef CancelableRequest1<HistoryService::QueryRedirectsCallback,
HistoryService::RedirectList>
QueryRedirectsRequest;
typedef CancelableRequest<HistoryService::GetVisitCountToHostCallback>
GetVisitCountToHostRequest;
// Thumbnails -----------------------------------------------------------------
typedef CancelableRequest<HistoryService::ThumbnailDataCallback>
GetPageThumbnailRequest;
// Favicons -------------------------------------------------------------------
typedef CancelableRequest<HistoryService::FavIconDataCallback>
GetFavIconRequest;
// Downloads ------------------------------------------------------------------
typedef CancelableRequest1<HistoryService::DownloadQueryCallback,
std::vector<DownloadCreateInfo> >
DownloadQueryRequest;
typedef CancelableRequest<HistoryService::DownloadCreateCallback>
DownloadCreateRequest;
typedef CancelableRequest1<HistoryService::DownloadSearchCallback,
std::vector<int64> >
DownloadSearchRequest;
// Deletion --------------------------------------------------------------------
typedef CancelableRequest<HistoryService::ExpireHistoryCallback>
ExpireHistoryRequest;
// Segment usage --------------------------------------------------------------
typedef CancelableRequest1<HistoryService::SegmentQueryCallback,
ScopedVector<PageUsageData> >
QuerySegmentUsageRequest;
// Keyword search terms -------------------------------------------------------
typedef
CancelableRequest1<HistoryService::GetMostRecentKeywordSearchTermsCallback,
std::vector<KeywordSearchTermVisit> >
GetMostRecentKeywordSearchTermsRequest;
// Generic operations ---------------------------------------------------------
// The argument here is an input value, which is the task to run on the
// background thread. The callback is used to execute the portion of the task
// that executes on the main thread.
typedef CancelableRequest1<HistoryService::HistoryDBTaskCallback,
scoped_refptr<HistoryDBTask> >
HistoryDBTaskRequest;
} // namespace history
#endif // CHROME_BROWSER_HISTORY_HISTORY_MARSHALING_H__
|