// 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/favicon_service.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::RefCountedThreadSafe { public: HistoryAddPageArgs(const GURL& arg_url, base::Time arg_time, const void* arg_id_scope, int32 arg_page_id, const GURL& arg_referrer, const history::RedirectList& arg_redirects, PageTransition::Type arg_transition, bool arg_did_replace_entry) : 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), did_replace_entry(arg_did_replace_entry) { } GURL url; base::Time time; const void* id_scope; int32 page_id; GURL referrer; history::RedirectList redirects; PageTransition::Type transition; bool did_replace_entry; private: friend class base::RefCountedThreadSafe; ~HistoryAddPageArgs() {} DISALLOW_EVIL_CONSTRUCTORS(HistoryAddPageArgs); }; // Querying ------------------------------------------------------------------- typedef CancelableRequest1 > QueryURLRequest; typedef CancelableRequest1 QueryHistoryRequest; typedef CancelableRequest1 QueryRedirectsRequest; typedef CancelableRequest GetVisitCountToHostRequest; typedef CancelableRequest1, history::RedirectMap> > QueryTopURLsAndRedirectsRequest; // Thumbnails ----------------------------------------------------------------- typedef CancelableRequest GetPageThumbnailRequest; // Favicons ------------------------------------------------------------------- typedef CancelableRequest GetFavIconRequest; // Downloads ------------------------------------------------------------------ typedef CancelableRequest1 > DownloadQueryRequest; typedef CancelableRequest DownloadCreateRequest; typedef CancelableRequest1 > DownloadSearchRequest; // Deletion -------------------------------------------------------------------- typedef CancelableRequest ExpireHistoryRequest; // Segment usage -------------------------------------------------------------- typedef CancelableRequest1 > QuerySegmentUsageRequest; // Keyword search terms ------------------------------------------------------- typedef CancelableRequest1 > 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 > HistoryDBTaskRequest; } // namespace history #endif // CHROME_BROWSER_HISTORY_HISTORY_MARSHALING_H__