// 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); }