| // Copyright (c) 2011 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 CHROME_BROWSER_AUTOCOMPLETE_HISTORY_PROVIDER_UTIL_H_ |
| #define CHROME_BROWSER_AUTOCOMPLETE_HISTORY_PROVIDER_UTIL_H_ |
| #pragma once |
| |
| #include <deque> |
| #include <vector> |
| |
| #include "chrome/browser/history/history_types.h" |
| |
| namespace history { |
| |
| // Used for intermediate history result operations. |
| struct HistoryMatch { |
| // Required for STL, we don't use this directly. |
| HistoryMatch(); |
| |
| HistoryMatch(const URLRow& url_info, |
| size_t input_location, |
| bool match_in_scheme, |
| bool innermost_match); |
| |
| bool operator==(const GURL& url) const; |
| |
| URLRow url_info; |
| |
| // The offset of the user's input within the URL. |
| size_t input_location; |
| |
| // Whether this is a match in the scheme. This determines whether we'll go |
| // ahead and show a scheme on the URL even if the user didn't type one. |
| // If our best match was in the scheme, not showing the scheme is both |
| // confusing and, for inline autocomplete of the fill_into_edit, dangerous. |
| // (If the user types "h" and we match "http://foo/", we need to inline |
| // autocomplete that, not "foo/", which won't show anything at all, and |
| // will mislead the user into thinking the What You Typed match is what's |
| // selected.) |
| bool match_in_scheme; |
| |
| // A match after any scheme/"www.", if the user input could match at both |
| // locations. If the user types "w", an innermost match ("website.com") is |
| // better than a non-innermost match ("www.google.com"). If the user types |
| // "x", no scheme in our prefix list (or "www.") begins with x, so all |
| // matches are, vacuously, "innermost matches". |
| bool innermost_match; |
| }; |
| typedef std::deque<HistoryMatch> HistoryMatches; |
| |
| struct Prefix { |
| Prefix(const string16& prefix, int num_components) |
| : prefix(prefix), |
| num_components(num_components) {} |
| |
| string16 prefix; |
| |
| // The number of "components" in the prefix. The scheme is a component, |
| // and the initial "www." or "ftp." is a component. So "http://foo.com" |
| // and "www.bar.com" each have one component, "ftp://ftp.ftp.com" has two, |
| // and "mysite.com" has none. This is used to tell whether the user's |
| // input is an innermost match or not. See comments in HistoryMatch. |
| int num_components; |
| }; |
| typedef std::vector<Prefix> Prefixes; |
| } |
| |
| #endif // CHROME_BROWSER_AUTOCOMPLETE_HISTORY_PROVIDER_UTIL_H_ |