// 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.
#include "chrome/browser/autocomplete/builtin_provider.h"
#include "base/string_util.h"
#include "base/utf_string_conversions.h"
#include "chrome/browser/autocomplete/autocomplete_match.h"
#include "chrome/browser/browser_about_handler.h"
#include "chrome/browser/net/url_fixer_upper.h"
const int BuiltinProvider::kRelevance = 575;
BuiltinProvider::BuiltinProvider(ACProviderListener* listener,
Profile* profile)
: AutocompleteProvider(listener, profile, "Builtin") {
std::vector<std::string> builtins(AboutPaths());
for (std::vector<std::string>::iterator i(builtins.begin());
i != builtins.end(); ++i)
builtins_.push_back(ASCIIToUTF16("about:") + ASCIIToUTF16(*i));
}
BuiltinProvider::~BuiltinProvider() {}
void BuiltinProvider::Start(const AutocompleteInput& input,
bool minimal_changes) {
matches_.clear();
if ((input.type() == AutocompleteInput::INVALID) ||
(input.type() == AutocompleteInput::FORCED_QUERY) ||
(input.type() == AutocompleteInput::QUERY) ||
(input.matches_requested() == AutocompleteInput::BEST_MATCH))
return;
for (Builtins::const_iterator i(builtins_.begin());
(i != builtins_.end()) && (matches_.size() < kMaxMatches); ++i) {
if (StartsWith(*i, input.text(), false)) {
AutocompleteMatch match(this, kRelevance, false,
AutocompleteMatch::NAVSUGGEST);
match.fill_into_edit = *i;
match.destination_url = GURL(*i);
match.contents = match.fill_into_edit;
match.contents_class.push_back(ACMatchClassification(0,
ACMatchClassification::MATCH | ACMatchClassification::URL));
if (match.contents.length() > input.text().length()) {
match.contents_class.push_back(
ACMatchClassification(input.text().length(),
ACMatchClassification::URL));
}
matches_.push_back(match);
}
}
for (size_t i = 0; i < matches_.size(); ++i)
matches_[i].relevance = kRelevance + matches_.size() - (i + 1);
}