OLD | NEW |
---|---|
(Empty) | |
1 // Copyright (c) 2013 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 #ifndef UI_ACCESSIBILITY_AX_TREE_SOURCE_H_ | |
6 #define UI_ACCESSIBILITY_AX_TREE_SOURCE_H_ | |
7 | |
8 #include "ui/accessibility/ax_node_data.h" | |
9 | |
10 namespace ui { | |
11 | |
12 // An AXTreeSource is an abstract interface for a serializable | |
13 // accessibility tree. The tree may be in some other format or | |
14 // may be computed dynamically, but maintains the properties that | |
15 // it's a strict tree, it has a unique id for each node, and all | |
16 // of the accessibility information about a node can be serialized | |
17 // as an AXNodeData. This is the primary interface to use when | |
18 // an accessibility tree will be sent over an IPC before being | |
19 // consumed. | |
20 template<class AXNodeSource> | |
21 class UI_EXPORT AXTreeSource { | |
22 public: | |
23 virtual AXNodeSource* GetFromId(int32 id) const = 0; | |
24 virtual int32 GetId(const AXNodeSource* node) const = 0; | |
25 virtual int GetChildCount(const AXNodeSource* node) const = 0; | |
26 virtual AXNodeSource* GetChildAtIndex(const AXNodeSource* node, int index) | |
27 const = 0; | |
28 | |
29 // Returns the id of this node's parent, or 0 if it doesn't have a parent. | |
30 virtual int32 GetParentId(const AXNodeSource* node) const = 0; | |
31 | |
32 // Serialize one node in the tree. | |
33 virtual void SerializeNode( | |
David Tseng
2013/11/15 18:05:31
Why not just serialize the entire subtree here and
dmazzoni
2013/11/18 08:09:25
Because the serializer needs to maintain state and
| |
34 const AXNodeSource* node, AXNodeData* out_data) const = 0; | |
35 | |
36 protected: | |
37 AXTreeSource() {} | |
38 virtual ~AXTreeSource() {} | |
39 }; | |
40 | |
41 } // namespace ui | |
42 | |
43 #endif // UI_ACCESSIBILITY_AX_TREE_SOURCE_H_ | |
OLD | NEW |