| OLD | NEW |
| 1 // Copyright (c) 2006-2008 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2006-2008 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 #ifndef CHROME_BROWSER_BROWSER_ACCESSIBILITY_MANAGER_H_ | 5 #ifndef CHROME_BROWSER_BROWSER_ACCESSIBILITY_MANAGER_H_ |
| 6 #define CHROME_BROWSER_BROWSER_ACCESSIBILITY_MANAGER_H_ | 6 #define CHROME_BROWSER_BROWSER_ACCESSIBILITY_MANAGER_H_ |
| 7 | 7 |
| 8 #include <oaidl.h> // Needed for VARIANT structure. | 8 #include <map> |
| 9 #include <hash_map> | |
| 10 | 9 |
| 11 #include "base/singleton.h" | 10 #include "base/singleton.h" |
| 12 #include "chrome/common/notification_observer.h" | 11 #include "chrome/common/notification_observer.h" |
| 13 #include "webkit/glue/webaccessibility.h" | 12 #include "webkit/glue/webaccessibility.h" |
| 14 | 13 |
| 15 class BrowserAccessibility; | 14 class BrowserAccessibility; |
| 16 class RenderProcessHost; | 15 class RenderProcessHost; |
| 17 class RenderWidgetHost; | 16 class RenderWidgetHost; |
| 18 | 17 |
| 18 using webkit_glue::WebAccessibility; |
| 19 |
| 19 //////////////////////////////////////////////////////////////////////////////// | 20 //////////////////////////////////////////////////////////////////////////////// |
| 20 // | 21 // |
| 21 // BrowserAccessibilityManager | 22 // BrowserAccessibilityManager |
| 22 // | 23 // |
| 23 // Used to manage instance creation and memory handling for browser side | 24 // Used to manage instance creation and memory handling for browser side |
| 24 // accessibility. A singleton class. It implements NotificationObserver to | 25 // accessibility. A singleton class. It implements NotificationObserver to |
| 25 // ensure that a termination of a renderer process gets propagated to the | 26 // ensure that a termination of a renderer process gets propagated to the |
| 26 // active BrowserAccessibility instances calling into it. Each such instance | 27 // active BrowserAccessibility instances calling into it. Each such instance |
| 27 // will upon such an event be set to an inactive state, failing calls from the | 28 // will upon such an event be set to an inactive state, failing calls from the |
| 28 // assistive technology gracefully. | 29 // assistive technology gracefully. |
| 29 //////////////////////////////////////////////////////////////////////////////// | 30 //////////////////////////////////////////////////////////////////////////////// |
| 30 class BrowserAccessibilityManager : public NotificationObserver { | 31 class BrowserAccessibilityManager : public NotificationObserver { |
| 31 public: | 32 public: |
| 32 // Gets the singleton BrowserAccessibilityManager object. The first time this | 33 // Gets the singleton BrowserAccessibilityManager object. The first time this |
| 33 // method is called, a CacheManagerHost object is constructed and returned. | 34 // method is called, a CacheManagerHost object is constructed and returned. |
| 34 // Subsequent calls will return the same object. | 35 // Subsequent calls will return the same object. |
| 35 static BrowserAccessibilityManager* GetInstance(); | 36 static BrowserAccessibilityManager* GetInstance(); |
| 36 | 37 |
| 37 // Creates an instance of BrowserAccessibility, initializes it and sets the | 38 // Creates an instance of BrowserAccessibility, initializes it and sets the |
| 38 // [acc_obj_id], which is used for IPC communication, and [instance_id], | 39 // |acc_obj_id|, which is used for IPC communication, and |instance_id|, |
| 39 // which is used to identify the mapping between accessibility instance and | 40 // which is used to identify the mapping between accessibility instance and |
| 40 // RenderProcess. | 41 // RenderProcess. |
| 41 STDMETHODIMP CreateAccessibilityInstance(REFIID iid, | 42 STDMETHODIMP CreateAccessibilityInstance(REFIID iid, |
| 42 int acc_obj_id, | 43 int acc_obj_id, |
| 43 int instance_id, | 44 int routing_id, |
| 45 int process_id, |
| 46 HWND parent_hwnd, |
| 44 void** interface_ptr); | 47 void** interface_ptr); |
| 45 | 48 |
| 46 // Composes and sends a message for requesting needed accessibility | 49 // Composes and sends a message for requesting needed accessibility |
| 47 // information. Unused LONG input parameters should be NULL, and the VARIANT | 50 // information. |
| 48 // [var_id] an empty, valid instance. | 51 bool RequestAccessibilityInfo(WebAccessibility::InParams* in, |
| 49 bool RequestAccessibilityInfo(int acc_obj_id, | 52 int routing_id, |
| 50 int instance_id, | 53 int process_id); |
| 51 int acc_func_id, | 54 |
| 52 int child_id, | 55 // Notifies assistive technology that renderer focus changed, through the |
| 53 long input1, | 56 // platform-specific channels. |
| 54 long input2); | 57 bool ChangeAccessibilityFocus(int acc_obj_id, int process_id, int routing_id); |
| 55 | 58 |
| 56 // Wrapper function, for cleaner code. | 59 // Wrapper function, for cleaner code. |
| 57 const webkit_glue::WebAccessibility::OutParams& response(); | 60 const WebAccessibility::OutParams& response(); |
| 58 | |
| 59 // Retrieves the parent HWND connected to the provided id. | |
| 60 HWND parent_hwnd(int id); | |
| 61 | |
| 62 // Mutator, needed since constructor does not take any arguments, and to keep | |
| 63 // instance accessor clean. | |
| 64 int SetMembers(BrowserAccessibility* browser_acc, | |
| 65 HWND parent_hwnd, | |
| 66 RenderWidgetHost* render_widget_host); | |
| 67 | 61 |
| 68 // NotificationObserver implementation. | 62 // NotificationObserver implementation. |
| 69 virtual void Observe(NotificationType type, | 63 virtual void Observe(NotificationType type, |
| 70 const NotificationSource& source, | 64 const NotificationSource& source, |
| 71 const NotificationDetails& details); | 65 const NotificationDetails& details); |
| 72 | 66 |
| 73 protected: | 67 protected: |
| 74 // This class is a singleton. Do not instantiate directly. | 68 // This class is a singleton. Do not instantiate directly. |
| 75 BrowserAccessibilityManager(); | 69 BrowserAccessibilityManager(); |
| 76 friend struct DefaultSingletonTraits<BrowserAccessibilityManager>; | 70 friend struct DefaultSingletonTraits<BrowserAccessibilityManager>; |
| 77 | 71 |
| 78 ~BrowserAccessibilityManager(); | 72 ~BrowserAccessibilityManager(); |
| 79 | 73 |
| 80 private: | 74 private: |
| 81 // Member variable structure, used in instance hashmap. | 75 // Retrieves the BrowserAccessibility instance connected to the |
| 82 struct UniqueMembers { | 76 // RenderProcessHost identified by the process/routing id pair. |
| 83 RenderWidgetHost* render_widget_host_; | 77 BrowserAccessibility* GetBrowserAccessibility(int process_id, int routing_id); |
| 84 HWND parent_hwnd_; | |
| 85 | 78 |
| 86 UniqueMembers(HWND parent_hwnd, RenderWidgetHost* render_widget_host) | 79 // Multi-map from process id (key) to active BrowserAccessibility instances |
| 87 : parent_hwnd_(parent_hwnd), | 80 // for that RenderProcessHost. |
| 88 render_widget_host_(render_widget_host) { | 81 typedef std::multimap<int, BrowserAccessibility*> RenderProcessHostMap; |
| 89 } | 82 typedef std::pair<int, BrowserAccessibility*> MapEntry; |
| 90 }; | |
| 91 | 83 |
| 92 typedef stdext::hash_map<int, UniqueMembers*> InstanceMap; | 84 // Mapping to track which RenderProcessHosts ids are active. If a |
| 93 typedef stdext::hash_map<RenderProcessHost*, BrowserAccessibility*> | 85 // RenderProcessHost is found to be terminated, its id (key) should be removed |
| 94 RenderProcessHostMap; | 86 // from this mapping, and the connected BrowserAccessibility ids/instances |
| 95 | 87 // invalidated. |
| 96 // Caching of the unique member variables used to handle browser accessibility | |
| 97 // requests from multiple processes. | |
| 98 InstanceMap instance_map_; | |
| 99 int instance_id_; | |
| 100 | |
| 101 // Reverse mapping to track which RenderProcessHosts are active. If a | |
| 102 // RenderProcessHost is found to be terminated, it should be removed from this | |
| 103 // mapping, and the connected BrowserAccessibility ids/instances invalidated. | |
| 104 RenderProcessHostMap render_process_host_map_; | 88 RenderProcessHostMap render_process_host_map_; |
| 105 | 89 |
| 106 webkit_glue::WebAccessibility::OutParams out_params_; | 90 // Structure passed by reference to hold response parameters from the |
| 91 // renderer. |
| 92 WebAccessibility::OutParams out_params_; |
| 107 | 93 |
| 108 DISALLOW_COPY_AND_ASSIGN(BrowserAccessibilityManager); | 94 DISALLOW_COPY_AND_ASSIGN(BrowserAccessibilityManager); |
| 109 }; | 95 }; |
| 110 #endif // CHROME_BROWSER_BROWSER_ACCESSIBILITY_MANAGER_H_ | 96 #endif // CHROME_BROWSER_BROWSER_ACCESSIBILITY_MANAGER_H_ |
| OLD | NEW |