Index: chrome/renderer/searchbox_extension.cc |
diff --git a/chrome/renderer/searchbox_extension.cc b/chrome/renderer/searchbox_extension.cc |
index 180e92c0caa057a0bea4a572abb035b955ccf0f0..2e268640cceb4c6b70d682e850338c9673ac3bda 100644 |
--- a/chrome/renderer/searchbox_extension.cc |
+++ b/chrome/renderer/searchbox_extension.cc |
@@ -276,25 +276,62 @@ v8::Handle<v8::Value> SearchBoxExtensionWrapper::GetHeight( |
return v8::Int32::New(render_view->searchbox().height); |
} |
+// Accepts a single argument in form: |
+// { |
+// suggestions: [ |
+// { |
+// value: "..." |
+// } |
+// ] |
+// } |
// static |
v8::Handle<v8::Value> SearchBoxExtensionWrapper::SetSuggestions( |
const v8::Arguments& args) { |
- if (!args.Length() || !args[0]->IsArray()) return v8::Undefined(); |
- |
std::vector<std::string> suggestions; |
- v8::Array* suggestions_arg = static_cast<v8::Array*>(*args[0]); |
- uint32_t length = suggestions_arg->Length(); |
- for (uint32_t i = 0; i < length; i++) { |
- std::string suggestion = *v8::String::Utf8Value( |
- suggestions_arg->Get(v8::Integer::New(i))->ToString()); |
- if (!suggestion.length()) continue; |
- suggestions.push_back(suggestion); |
- } |
- RenderView* render_view = GetRenderView(); |
- if (!render_view) return v8::Undefined(); |
+ if (args.Length() && args[0]->IsArray()) { |
+ // For backwards compatibility, also accept an array of strings. |
+ // TODO(tonyg): Remove this when it is confirmed to be unused. |
+ v8::Array* suggestions_array = static_cast<v8::Array*>(*args[0]); |
+ uint32_t length = suggestions_array->Length(); |
+ for (uint32_t i = 0; i < length; i++) { |
+ std::string suggestion = *v8::String::Utf8Value( |
+ suggestions_array->Get(v8::Integer::New(i))->ToString()); |
+ if (!suggestion.length()) continue; |
+ suggestions.push_back(suggestion); |
+ } |
+ } else if (args.Length() && args[0]->IsObject()) { |
+ // Standard version, object argument. |
+ v8::Object* suggestion_json = static_cast<v8::Object*>(*args[0]); |
+ v8::Local<v8::Value> suggestions_field = |
+ suggestion_json->Get(v8::String::New("suggestions")); |
+ |
+ if (suggestions_field->IsArray()) { |
+ v8::Local<v8::Array> suggestions_array = |
+ suggestions_field.As<v8::Array>(); |
+ |
+ uint32_t length = suggestions_array->Length(); |
+ for (uint32_t i = 0; i < length; i++) { |
+ v8::Local<v8::Value> suggestion_value = |
+ suggestions_array->Get(v8::Integer::New(i)); |
+ if (!suggestion_value->IsObject()) continue; |
+ |
+ v8::Local<v8::Object> suggestion_object = |
+ suggestion_value.As<v8::Object>(); |
+ v8::Local<v8::Value> suggestion_object_value = |
+ suggestion_object->Get(v8::String::New("value")); |
+ if (!suggestion_object_value->IsString()) continue; |
+ |
+ std::string suggestion = *v8::String::Utf8Value( |
+ suggestion_object_value->ToString()); |
+ if (!suggestion.length()) continue; |
+ suggestions.push_back(suggestion); |
+ } |
+ } |
+ } |
- render_view->SetSuggestions(suggestions); |
+ if (RenderView* render_view = GetRenderView()) |
+ render_view->SetSuggestions(suggestions); |
return v8::Undefined(); |
} |