| Index: chrome/browser/accessibility/accessibility_extension_api.cc
|
| diff --git a/chrome/browser/accessibility/accessibility_extension_api.cc b/chrome/browser/accessibility/accessibility_extension_api.cc
|
| index e2c9fa9d661ca41c635c58fac827824ac30f51d3..9a2258a80cffabb4b43efe1bcebac2e7e788b59b 100644
|
| --- a/chrome/browser/accessibility/accessibility_extension_api.cc
|
| +++ b/chrome/browser/accessibility/accessibility_extension_api.cc
|
| @@ -25,14 +25,13 @@ namespace keys = extension_accessibility_api_constants;
|
| // Returns the AccessibilityControlInfo serialized into a JSON string,
|
| // consisting of an array of a single object of type AccessibilityObject,
|
| // as defined in the accessibility extension api's json schema.
|
| -std::string ControlInfoToJsonString(const AccessibilityEventInfo* info) {
|
| - ListValue args;
|
| +ListValue* ControlInfoToEventArguments(const AccessibilityEventInfo* info) {
|
| DictionaryValue* dict = new DictionaryValue();
|
| info->SerializeToDict(dict);
|
| - args.Append(dict);
|
| - std::string json_args;
|
| - base::JSONWriter::Write(&args, &json_args);
|
| - return json_args;
|
| +
|
| + ListValue* args = new ListValue();
|
| + args->Append(dict);
|
| + return args;
|
| }
|
|
|
| ExtensionAccessibilityEventRouter*
|
| @@ -116,55 +115,55 @@ bool ExtensionAccessibilityEventRouter::IsAccessibilityEnabled() const {
|
|
|
| void ExtensionAccessibilityEventRouter::OnWindowOpened(
|
| const AccessibilityWindowInfo* info) {
|
| - std::string json_args = ControlInfoToJsonString(info);
|
| - DispatchEvent(info->profile(), keys::kOnWindowOpened, json_args);
|
| + ListValue* args = ControlInfoToEventArguments(info);
|
| + DispatchEvent(info->profile(), keys::kOnWindowOpened, args);
|
| }
|
|
|
| void ExtensionAccessibilityEventRouter::OnWindowClosed(
|
| const AccessibilityWindowInfo* info) {
|
| - std::string json_args = ControlInfoToJsonString(info);
|
| - DispatchEvent(info->profile(), keys::kOnWindowClosed, json_args);
|
| + ListValue* args = ControlInfoToEventArguments(info);
|
| + DispatchEvent(info->profile(), keys::kOnWindowClosed, args);
|
| }
|
|
|
| void ExtensionAccessibilityEventRouter::OnControlFocused(
|
| const AccessibilityControlInfo* info) {
|
| last_focused_control_dict_.Clear();
|
| info->SerializeToDict(&last_focused_control_dict_);
|
| - std::string json_args = ControlInfoToJsonString(info);
|
| - DispatchEvent(info->profile(), keys::kOnControlFocused, json_args);
|
| + ListValue* args = ControlInfoToEventArguments(info);
|
| + DispatchEvent(info->profile(), keys::kOnControlFocused, args);
|
| }
|
|
|
| void ExtensionAccessibilityEventRouter::OnControlAction(
|
| const AccessibilityControlInfo* info) {
|
| - std::string json_args = ControlInfoToJsonString(info);
|
| - DispatchEvent(info->profile(), keys::kOnControlAction, json_args);
|
| + ListValue* args = ControlInfoToEventArguments(info);
|
| + DispatchEvent(info->profile(), keys::kOnControlAction, args);
|
| }
|
|
|
| void ExtensionAccessibilityEventRouter::OnTextChanged(
|
| const AccessibilityControlInfo* info) {
|
| - std::string json_args = ControlInfoToJsonString(info);
|
| - DispatchEvent(info->profile(), keys::kOnTextChanged, json_args);
|
| + ListValue* args = ControlInfoToEventArguments(info);
|
| + DispatchEvent(info->profile(), keys::kOnTextChanged, args);
|
| }
|
|
|
| void ExtensionAccessibilityEventRouter::OnMenuOpened(
|
| const AccessibilityMenuInfo* info) {
|
| - std::string json_args = ControlInfoToJsonString(info);
|
| - DispatchEvent(info->profile(), keys::kOnMenuOpened, json_args);
|
| + ListValue* args = ControlInfoToEventArguments(info);
|
| + DispatchEvent(info->profile(), keys::kOnMenuOpened, args);
|
| }
|
|
|
| void ExtensionAccessibilityEventRouter::OnMenuClosed(
|
| const AccessibilityMenuInfo* info) {
|
| - std::string json_args = ControlInfoToJsonString(info);
|
| - DispatchEvent(info->profile(), keys::kOnMenuClosed, json_args);
|
| + ListValue* args = ControlInfoToEventArguments(info);
|
| + DispatchEvent(info->profile(), keys::kOnMenuClosed, args);
|
| }
|
|
|
| void ExtensionAccessibilityEventRouter::DispatchEvent(
|
| Profile* profile,
|
| const char* event_name,
|
| - const std::string& json_args) {
|
| + base::ListValue* event_args) {
|
| if (enabled_ && profile && profile->GetExtensionEventRouter()) {
|
| profile->GetExtensionEventRouter()->DispatchEventToRenderers(
|
| - event_name, json_args, NULL, GURL(), extensions::EventFilteringInfo());
|
| + event_name, event_args, NULL, GURL(), extensions::EventFilteringInfo());
|
| }
|
| }
|
|
|
|
|