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

Side by Side Diff: chrome/browser/ui/webui/omnibox/omnibox_ui_handler.cc

Issue 9289028: Make chrome://omnibox/ be able to report per-provider matches. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Created 8 years, 11 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 | Annotate | Revision Log
OLDNEW
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #include "chrome/browser/ui/webui/omnibox/omnibox_ui_handler.h" 5 #include "chrome/browser/ui/webui/omnibox/omnibox_ui_handler.h"
6 6
7 #include <string> 7 #include <string>
8 8
9 #include "base/bind.h" 9 #include "base/bind.h"
10 #include "base/string16.h" 10 #include "base/string16.h"
(...skipping 17 matching lines...) Expand all
28 base::Unretained(this))); 28 base::Unretained(this)));
29 } 29 }
30 30
31 // This function gets called when the AutocompleteController possibly 31 // This function gets called when the AutocompleteController possibly
32 // has new results. We package those results in a DictionaryValue 32 // has new results. We package those results in a DictionaryValue
33 // object result_to_output and call the javascript function 33 // object result_to_output and call the javascript function
34 // handleNewAutocompleteResult. Here's an example populated 34 // handleNewAutocompleteResult. Here's an example populated
35 // result_to_output object: 35 // result_to_output object:
36 // { 'done': false, 36 // { 'done': false,
37 // 'time_since_omnibox_started_ms': 15, 37 // 'time_since_omnibox_started_ms': 15,
38 // 'num_items': 4, 38 // 'combined_results' :
39 // 'item_0': { 39 // { 'num_items': 4,
40 // 'destination_url': 'http://mail.google.com', 40 // 'item_0':
41 // 'provider_name': 'HistoryURL', 41 // { 'destination_url': 'http://mail.google.com',
42 // 'relevance': 1410, 42 // 'provider_name': 'HistoryURL',
43 // 'is_default_match': true, 43 // 'relevance': 1410,
44 // ... 44 // ...
45 // } 45 // }
46 // 'item_1: { 46 // 'item_1: {
47 // ... 47 // ...
48 // } 48 // }
49 // ... 49 // ...
50 // }
51 // 'results_by_provider':
52 // { 'HistoryURL' :
53 // { 'num_items': 3,
54 // ...
55 // }
56 // 'Search' :
57 // { 'num_items': 1,
58 // ...
59 // }
60 // ...
61 // }
50 // } 62 // }
51 // For reference, the javascript code that unpacks this object and 63 // For reference, the javascript code that unpacks this object and
52 // displays it is in chrome/browser/resources/omnibox.js 64 // displays it is in chrome/browser/resources/omnibox.js
53 //
54 // TODO(mpearson): Instead of iterating over the sorted-and-
55 // duplicate-eliminated results, perhaps it would be useful to also
56 // poll all the AutocompleteController's providers. This will require
57 // changing the AutocompleteController's interface.
58 void OmniboxUIHandler::OnResultChanged(bool default_match_changed) { 65 void OmniboxUIHandler::OnResultChanged(bool default_match_changed) {
59 const AutocompleteResult& result = controller_->result();
60 base::DictionaryValue result_to_output; 66 base::DictionaryValue result_to_output;
61 // Fill in result-level information. 67 // Fill in general information.
62 result_to_output.SetBoolean("done", controller_->done()); 68 result_to_output.SetBoolean("done", controller_->done());
63 result_to_output.SetInteger("time_since_omnibox_started_ms", 69 result_to_output.SetInteger("time_since_omnibox_started_ms",
64 (base::Time::Now() - time_omnibox_started_).InMilliseconds()); 70 (base::Time::Now() - time_omnibox_started_).InMilliseconds());
65 result_to_output.SetInteger("num_items", result.size()); 71 // Fill in the merged/combined results the controller has provided.
66 // Fill in per-match information. 72 AddResultToDictionary("combined_results", controller_->result().begin(),
73 controller_->result().end(), &result_to_output);
74 // Fill results from each individual provider as well.
75 for (ACProviders::const_iterator it(controller_->providers_.begin());
76 it != controller_->providers_.end(); ++it)
Evan Stade 2012/01/26 00:32:56 curlies
Mark P 2012/01/26 22:11:59 Done.
77 AddResultToDictionary(std::string("results_by_provider.") + (*it)->name(),
78 (*it)->matches().begin(), (*it)->matches().end(), &result_to_output);
79 // Add done; send the results.
80 web_ui()->CallJavascriptFunction("omniboxDebug.handleNewAutocompleteResult",
81 result_to_output);
82 }
83
84 // For details on the format of the DictionaryValue that this function
85 // populates, see the comments by OnResultChanged().
86 void OmniboxUIHandler::AddResultToDictionary(const std::string prefix,
87 ACMatches::const_iterator it,
88 ACMatches::const_iterator end,
89 base::DictionaryValue* output) {
67 int i = 0; 90 int i = 0;
68 for (ACMatches::const_iterator it = result.begin(); it != result.end(); 91 for (; it != end; ++it, ++i) {
69 ++it, ++i) { 92 std::string item_prefix(prefix + StringPrintf(".item_%d", i));
70 std::string prefix(StringPrintf("item_%d", i));
71 if (it->provider != NULL) { 93 if (it->provider != NULL) {
72 result_to_output.SetString(prefix + ".provider_name", 94 output->SetString(item_prefix + ".provider_name", it->provider->name());
73 it->provider->name()); 95 output->SetBoolean(item_prefix + ".provider_done", it->provider->done());
74 result_to_output.SetBoolean(prefix + ".provider_done",
75 it->provider->done());
76 } 96 }
77 result_to_output.SetInteger(prefix + ".relevance", it->relevance); 97 output->SetInteger(item_prefix + ".relevance", it->relevance);
78 result_to_output.SetBoolean(prefix + ".deletable", it->deletable); 98 output->SetBoolean(item_prefix + ".deletable", it->deletable);
79 result_to_output.SetString(prefix + ".fill_into_edit", it->fill_into_edit); 99 output->SetString(item_prefix + ".fill_into_edit", it->fill_into_edit);
80 result_to_output.SetInteger(prefix + ".inline_autocomplete_offset", 100 output->SetInteger(item_prefix + ".inline_autocomplete_offset",
81 it->inline_autocomplete_offset); 101 it->inline_autocomplete_offset);
82 result_to_output.SetString(prefix + ".destination_url", 102 output->SetString(item_prefix + ".destination_url",
83 it->destination_url.spec()); 103 it->destination_url.spec());
84 result_to_output.SetString(prefix + ".contents", it->contents); 104 output->SetString(item_prefix + ".contents", it->contents);
85 // At this time, we're not bothering to send along the long vector that 105 // At this time, we're not bothering to send along the long vector that
86 // represent contents classification. i.e., for each character, what 106 // represent contents classification. i.e., for each character, what
87 // type of text it is. 107 // type of text it is.
88 result_to_output.SetString(prefix + ".description", it->description); 108 output->SetString(item_prefix + ".description", it->description);
89 // At this time, we're not bothering to send along the long vector that 109 // At this time, we're not bothering to send along the long vector that
90 // represents description classification. i.e., for each character, what 110 // represents description classification. i.e., for each character, what
91 // type of text it is. 111 // type of text it is.
92 result_to_output.SetInteger(prefix + ".transition", it->transition); 112 output->SetInteger(item_prefix + ".transition", it->transition);
93 result_to_output.SetBoolean(prefix + ".is_history_what_you_typed_match", 113 output->SetBoolean(item_prefix + ".is_history_what_you_typed_match",
94 it->is_history_what_you_typed_match); 114 it->is_history_what_you_typed_match);
95 result_to_output.SetString(prefix + ".type", 115 output->SetString(item_prefix + ".type",
96 AutocompleteMatch::TypeToString(it->type)); 116 AutocompleteMatch::TypeToString(it->type));
97 if ((it->template_url != NULL) && (it->template_url->url() != NULL)) { 117 if ((it->template_url != NULL) && (it->template_url->url() != NULL)) {
98 result_to_output.SetString(prefix + ".template_url", 118 output->SetString(item_prefix + ".template_url",
99 it->template_url->url()->url()); 119 it->template_url->url()->url());
100 } 120 }
101 result_to_output.SetBoolean(prefix + ".starred", it->starred); 121 output->SetBoolean(item_prefix + ".starred", it->starred);
102 result_to_output.SetBoolean(prefix + ".from_previous", it->from_previous); 122 output->SetBoolean(item_prefix + ".from_previous", it->from_previous);
103 result_to_output.SetBoolean(prefix + ".is_default_match",
Mark P 2012/01/25 23:21:08 I removed is_default_match because keeping it woul
104 it == result.default_match());
105 } 123 }
106 web_ui()->CallJavascriptFunction("omniboxDebug.handleNewAutocompleteResult", 124 output->SetInteger(prefix + ".num_items", i);
107 result_to_output);
108 } 125 }
109 126
110 void OmniboxUIHandler::StartOmniboxQuery( 127 void OmniboxUIHandler::StartOmniboxQuery(
111 const base::ListValue* one_element_input_string) { 128 const base::ListValue* one_element_input_string) {
112 string16 input_string = ExtractStringValue(one_element_input_string); 129 string16 input_string = ExtractStringValue(one_element_input_string);
113 string16 empty_string; 130 string16 empty_string;
114 // Tell the autocomplete controller to start working on the 131 // Tell the autocomplete controller to start working on the
115 // input. It's okay if the previous request hasn't yet finished; 132 // input. It's okay if the previous request hasn't yet finished;
116 // the autocomplete controller is smart enough to stop the previous 133 // the autocomplete controller is smart enough to stop the previous
117 // query before it starts the new one. By the way, in this call to 134 // query before it starts the new one. By the way, in this call to
118 // Start(), we use the default/typical values for all parameters. 135 // Start(), we use the default/typical values for all parameters.
119 time_omnibox_started_ = base::Time::Now(); 136 time_omnibox_started_ = base::Time::Now();
120 controller_->Start(input_string, 137 controller_->Start(input_string,
121 empty_string, // user's desired tld (top-level domain) 138 empty_string, // user's desired tld (top-level domain)
122 false, // don't prevent inline autocompletion 139 false, // don't prevent inline autocompletion
123 false, // no preferred keyword provider 140 false, // no preferred keyword provider
124 true, // allow exact keyword matches 141 true, // allow exact keyword matches
125 AutocompleteInput::ALL_MATCHES); // want all matches 142 AutocompleteInput::ALL_MATCHES); // want all matches
126 } 143 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698