Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(823)

Side by Side Diff: components/open_from_clipboard/clipboard_url_provider.cc

Issue 930323003: Upstream iOS' Open from Clipboard component. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Updated actions.xml Created 5 years, 10 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
(Empty)
1 // Copyright 2015 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
4
5 #include "components/open_from_clipboard/clipboard_url_provider.h"
6
7 #include "base/logging.h"
8 #include "base/strings/utf_string_conversions.h"
9 #include "components/omnibox/autocomplete_input.h"
10 #include "components/open_from_clipboard/clipboard_recent_content.h"
11 #include "grit/components_strings.h"
12 #include "ui/base/l10n/l10n_util.h"
13
14 namespace {
15 // Score defining the priority of the suggestion. 1600 guarantees that the
16 // suggestion will always be first. See table in autocomplete_provider.h.
17 const int kClipboardURLProviderRelevance = 1600;
18 } // namespace
19
20 ClipboardURLProvider::ClipboardURLProvider(
21 ClipboardRecentContent* clipboard_recent_content)
22 : AutocompleteProvider(AutocompleteProvider::TYPE_SHORTCUTS),
23 clipboard_recent_content_(clipboard_recent_content) {
24 DCHECK(clipboard_recent_content_);
25 }
26
27 ClipboardURLProvider::~ClipboardURLProvider() {
28 }
29
30 void ClipboardURLProvider::Start(const AutocompleteInput& input,
31 bool minimal_changes,
32 bool called_due_to_focus) {
33 matches_.clear();
34 // Attempt to add an AutocompleteMatch only if the user has not entered
35 // anything in the omnibox.
36 if (input.cursor_position() == base::string16::npos) {
37 GURL url;
38 if (clipboard_recent_content_->GetRecentURLFromClipboard(&url)) {
39 DCHECK(url.is_valid());
40 AutocompleteMatch match(this, kClipboardURLProviderRelevance, false,
41 AutocompleteMatchType::NAVSUGGEST_PERSONALIZED);
42 match.allowed_to_be_default_match = true;
43 match.destination_url = url;
44 match.contents.assign(base::UTF8ToUTF16(url.spec()));
45 AutocompleteMatch::ClassifyLocationInString(
46 base::string16::npos, 0, match.contents.length(),
47 ACMatchClassification::URL, &match.contents_class);
48
49 match.description.assign(
50 l10n_util::GetStringUTF16(IDS_LINK_FROM_CLIPBOARD));
51 AutocompleteMatch::ClassifyLocationInString(
52 base::string16::npos, 0, match.description.length(),
53 ACMatchClassification::URL, &match.description_class);
54
55 matches_.push_back(match);
56 }
57 }
58 done_ = true;
59 }
OLDNEW
« no previous file with comments | « components/open_from_clipboard/clipboard_url_provider.h ('k') | components/open_from_clipboard_strings.grdp » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698