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

Unified Diff: iaccessible_hack2.h

Issue 1183633003: cross gn Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: slightly smaller diff Created 4 years, 5 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 side-by-side diff with in-line comments
Download patch
« no previous file with comments | « content/browser/accessibility/browser_accessibility_win.h ('k') | ppapi/tests/ppapi_nacl_tests_newlib.nmf » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: iaccessible_hack2.h
diff --git a/iaccessible_hack2.h b/iaccessible_hack2.h
new file mode 100644
index 0000000000000000000000000000000000000000..3f43743be4f1301c7a646edacc85611fba40dbe7
--- /dev/null
+++ b/iaccessible_hack2.h
@@ -0,0 +1,1104 @@
+#ifndef LOLLOLLOL
+#define LOLLOLLOL
+#include <atlbase.h>
+#include <UIAutomationCore.h>
+
+typedef int AccessibleStates;
+class IA2Locale;
+class IA2TableModelChange;
+
+struct IA2TextSegment {
+ BSTR text;
+ long start, end;
+};
+
+extern __declspec(selectany) const IID IID_IAccessibleText = {};
+extern __declspec(selectany) const IID IID_IAccessible2 = {};
+extern __declspec(selectany) const IID IID_IAccessible2_2 = {};
+extern __declspec(selectany) const IID LIBID_IAccessible2Lib = {};
+extern __declspec(selectany) const IID IID_IAccessibleAction = {};
+extern __declspec(selectany) const IID IID_IAccessibleApplication = {};
+extern __declspec(selectany) const IID IID_IAccessibleHyperlink = {};
+extern __declspec(selectany) const IID IID_IAccessibleHypertext = {};
+extern __declspec(selectany) const IID IID_IAccessibleImage = {};
+extern __declspec(selectany) const IID IID_IAccessibleTable = {};
+extern __declspec(selectany) const IID IID_IAccessibleTable2 = {};
+extern __declspec(selectany) const IID IID_IAccessibleTableCell = {};
+extern __declspec(selectany) const IID IID_IAccessibleValue = {};
+extern __declspec(selectany) const IID IID_ISimpleDOMDocument = {};
+extern __declspec(selectany) const IID IID_ISimpleDOMNode = {};
+extern __declspec(selectany) const IID IID_ISimpleDOMText = {};
+
+
+enum IA2TextBoundaryType {
+IA2_TEXT_BOUNDARY_ALL,
+IA2_TEXT_BOUNDARY_CHAR,
+IA2_TEXT_BOUNDARY_LINE,
+IA2_TEXT_BOUNDARY_PARAGRAPH,
+IA2_TEXT_BOUNDARY_SENTENCE,
+IA2_TEXT_BOUNDARY_WORD,
+};
+
+enum IA2ScrollType {
+ IA2_SCROLL_TYPE_TOP_LEFT,
+ IA2_SCROLL_TYPE_BOTTOM_RIGHT,
+ IA2_SCROLL_TYPE_TOP_EDGE,
+ IA2_SCROLL_TYPE_BOTTOM_EDGE,
+ IA2_SCROLL_TYPE_LEFT_EDGE,
+ IA2_SCROLL_TYPE_RIGHT_EDGE,
+ IA2_SCROLL_TYPE_ANYWHERE,
+};
+enum IA2States {
+
+/** Indicates a window is currently the active window, or is an active subelement
+ within a container or table.
+
+ This state can be used to indicate the current active item in a container, even
+ if the container itself is not currently active. In other words this would indicate
+ the item that will get focus if you tab to the container.
+
+ This information is important for knowing what to report for trees and potentially
+ other containers in a virtual buffer.
+
+ Also, see ::IA2_STATE_MANAGES_DESCENDANTS for more information.
+*/
+IA2_STATE_ACTIVE = 0x1,
+
+/** Indicates that the object is armed.
+
+ Used to indicate that the control is "pressed" and will be invoked when the
+ actuator, e.g. a mouse button, is "released". An AT which either monitors the
+ mouse or synthesizes mouse events might need to know that, and possibly a talking
+ interface would even let the user know about it. It could also potentially be
+ useful to on screen keyboards or test tools since the information does indicate
+ something about the state of the interface, for example, code operating asynchronously
+ might need to wait for the armed state to change before doing something else.
+
+*/
+IA2_STATE_ARMED = 0x2,
+
+/** Indicates the user interface object corresponding to this object no longer exists. */
+IA2_STATE_DEFUNCT = 0x4,
+
+/** An object with this state has a caret and implements the IAccessibleText interface.
+
+ Such fields may be read-only, so STATE_SYSTEM_READONLY is valid in combination
+ with IA2_STATE_EDITABLE.
+
+*/
+IA2_STATE_EDITABLE = 0x8,
+
+/** Indicates the orientation of this object is horizontal. */
+IA2_STATE_HORIZONTAL = 0x10,
+
+/** Indicates this object is minimized and is represented only by an icon. */
+IA2_STATE_ICONIFIED = 0x20,
+
+/** Indicates an input validation failure. */
+IA2_STATE_INVALID_ENTRY = 0x40,
+
+/** Indicates that this object manages its children.
+
+ Note: Due to the fact that MSAA's WinEvents don't allow the active child index
+ to be passed on the IA2_EVENT_ACTIVE_DESCENDANT_CHANGED event, the manages
+ descendants scheme can't be used. Instead the active child object has to fire
+ MSAA's EVENT_OBJECT_FOCUS. In a future release a new event mechanism may be
+ added to provide for event specific data to be passed with the event. At that
+ time the IA2_EVENT_ACTIVE_DECENDENT_CHANGED event and
+ IA2_STATE_MANAGES_DESCENDANTS state would be useful.
+*/
+IA2_STATE_MANAGES_DESCENDANTS = 0x80,
+
+/** Indicates that an object is modal.
+
+ Modal objects have the behavior that something must be done with the object
+ before the user can interact with an object in a different window.
+*/
+IA2_STATE_MODAL = 0x100,
+
+/** Indicates this text object can contain multiple lines of text. */
+IA2_STATE_MULTI_LINE = 0x200,
+
+/** Indicates this object paints every pixel within its rectangular region. */
+IA2_STATE_OPAQUE = 0x400,
+
+/** Indicates that user interaction is required.
+
+ An example of when this state is used is when a field in a form must be filled
+ before a form can be processed.
+*/
+IA2_STATE_REQUIRED = 0x800,
+
+/** Indicates an object which supports text selection.
+
+ Note: This is different than MSAA STATE_SYSTEM_SELECTABLE.
+*/
+IA2_STATE_SELECTABLE_TEXT = 0x1000,
+
+/** Indicates that this text object can contain only a single line of text. */
+IA2_STATE_SINGLE_LINE = 0x2000,
+
+/** Indicates that the accessible object is stale.
+
+ This state is used when the accessible object no longer accurately
+ represents the state of the object which it is representing such as when an
+ object is transient or when an object has been or is in the process of being
+ destroyed or when the object's index in its parent has changed.
+*/
+IA2_STATE_STALE = 0x4000,
+
+/** Indicates that the object implements autocompletion.
+
+ This state indicates that a text control will respond to the input of
+ one ore more characters and cause a sub-item to become selected. The
+ selection may also result in events fired on the parent object.
+*/
+IA2_STATE_SUPPORTS_AUTOCOMPLETION = 0x8000,
+
+/** Indicates this object is transient.
+
+ An object has this state when its parent object has the state ::IA2_STATE_MANAGES_DESCENDANTS.
+ For example, a list item object may be managed by its parent list object and may only
+ exist as long as the object is actually rendered. Similarly a table cell's accessible
+ object may exist only while the cell has focus. However, from the perspective of an
+ assistive technology a transient object behaves like a non-transient object. As a
+ result it is likely that this state is not of use to an assistive technology, but it
+ is provided in case an assistive technology determines that knowledge of the transient
+ nature of the object is useful and also for harmony with the Linux accessibility API.
+
+ Also, see ::IA2_STATE_MANAGES_DESCENDANTS for more information.
+ */
+IA2_STATE_TRANSIENT = 0x10000,
+
+/** Indicates the orientation of this object is vertical. */
+IA2_STATE_VERTICAL = 0x20000,
+
+/** Indicates this object is checkable.
+
+ The standard checkable objects are check boxes, radio buttons, check box menu
+ items, radio menu items, and toggle buttons. Since assistive technology will
+ determine that these objects are checkable via the object's role the checkable
+ state is not required. However, this state is necessary in those cases where
+ an object has a role which is not one of the previously mentioned roles. An
+ example is a table cell which indicates whether or not an email has an attachment,
+ whether or not an mail is considered spam, and whether or not an email has been read.
+ */
+IA2_STATE_CHECKABLE = 0x40000,
+
+/** Indicates this object is pinned.
+
+ This state indicates that an object is fixed at a certain location. One example
+ is a browser tab that when pinned cannot be moved until unpinned. Another example
+ is a movable or floating object that when pinned remains in its pinned location
+ until being unpinned.
+ */
+IA2_STATE_PINNED = 0x80000
+
+};
+enum IA2Role {
+
+ /** Unknown role. The object contains some Accessible information, but its
+ role is not known.
+ */
+ IA2_ROLE_UNKNOWN = 0,
+
+ /** An object that can be drawn into and to manage events from the objects
+ drawn into it. Also refer to ::IA2_ROLE_FRAME,
+ ::IA2_ROLE_GLASS_PANE, and ::IA2_ROLE_LAYERED_PANE.
+ */
+ IA2_ROLE_CANVAS = 0x401,
+
+ /// A caption describing another object.
+ IA2_ROLE_CAPTION,
+
+ /// Used for check buttons that are menu items.
+ IA2_ROLE_CHECK_MENU_ITEM,
+
+ /// A specialized dialog that lets the user choose a color.
+ IA2_ROLE_COLOR_CHOOSER,
+
+ /// A date editor.
+ IA2_ROLE_DATE_EDITOR,
+
+ /** An iconified internal frame in an ::IA2_ROLE_DESKTOP_PANE.
+ Also refer to ::IA2_ROLE_INTERNAL_FRAME.
+ */
+ IA2_ROLE_DESKTOP_ICON,
+
+ /** A desktop pane. A pane that supports internal frames and iconified
+ versions of those internal frames. Also refer to ::IA2_ROLE_INTERNAL_FRAME.
+ */
+ IA2_ROLE_DESKTOP_PANE,
+
+ /** A directory pane. A pane that allows the user to navigate through
+ and select the contents of a directory. May be used by a file chooser.
+ Also refer to ::IA2_ROLE_FILE_CHOOSER.
+ */
+ IA2_ROLE_DIRECTORY_PANE,
+
+ /** An editable text object in a toolbar. <b>Deprecated.</b>
+ The edit bar role was meant for a text area in a tool bar. However, to detect
+ a text area in a tool bar the AT can query the parent.
+ */
+ IA2_ROLE_EDITBAR,
+
+ /// Embedded (OLE) object.
+ IA2_ROLE_EMBEDDED_OBJECT,
+
+ /// Text that is used as an endnote (footnote at the end of a chapter or section).
+ IA2_ROLE_ENDNOTE,
+
+ /** A file chooser. A specialized dialog that displays the files in the
+ directory and lets the user select a file, browse a different directory,
+ or specify a filename. May use the directory pane to show the contents of
+ a directory.
+ Also refer to ::IA2_ROLE_DIRECTORY_PANE.
+ */
+ IA2_ROLE_FILE_CHOOSER,
+
+ /** A font chooser. A font chooser is a component that lets the user pick
+ various attributes for fonts.
+ */
+ IA2_ROLE_FONT_CHOOSER,
+
+ /** Footer of a document page.
+ Also refer to ::IA2_ROLE_HEADER.
+ */
+ IA2_ROLE_FOOTER,
+
+ /// Text that is used as a footnote. Also refer to ::IA2_ROLE_ENDNOTE.
+ IA2_ROLE_FOOTNOTE,
+
+ /** A container of form controls. An example of the use of this role is to
+ represent an HTML FORM tag.
+ */
+ IA2_ROLE_FORM,
+
+ /** Frame role. A top level window with a title bar, border, menu bar, etc.
+ It is often used as the primary window for an application. Also refer to
+ ::IA2_ROLE_CANVAS and the MSAA roles of dialog and window.
+ */
+ IA2_ROLE_FRAME,
+
+ /** A glass pane. A pane that is guaranteed to be painted on top of all panes
+ beneath it. Also refer to ::IA2_ROLE_CANVAS, ::IA2_ROLE_INTERNAL_FRAME, and
+ ::IA2_ROLE_ROOT_PANE.
+ */
+ IA2_ROLE_GLASS_PANE,
+
+ /** Header of a document page.
+ Also refer to ::IA2_ROLE_FOOTER.
+ */
+ IA2_ROLE_HEADER,
+
+ /// Heading. Use the IAccessible2::attributes level attribute to determine the heading level.
+ IA2_ROLE_HEADING,
+
+ /// A small fixed size picture, typically used to decorate components.
+ IA2_ROLE_ICON,
+
+ /** An image map object. Usually a graphic with multiple hotspots, where
+ each hotspot can be activated resulting in the loading of another document
+ or section of a document.
+ */
+ IA2_ROLE_IMAGE_MAP,
+
+ /** An object which is used to allow input of characters not found on a keyboard,
+ such as the input of Chinese characters on a Western keyboard.
+ */
+ IA2_ROLE_INPUT_METHOD_WINDOW,
+
+ /** An internal frame. A frame-like object that is clipped by a desktop pane.
+ The desktop pane, internal frame, and desktop icon objects are often used to
+ create multiple document interfaces within an application.
+ Also refer to ::IA2_ROLE_DESKTOP_ICON, ::IA2_ROLE_DESKTOP_PANE, and ::IA2_ROLE_FRAME.
+ */
+ IA2_ROLE_INTERNAL_FRAME,
+
+ /// An object used to present an icon or short string in an interface.
+ IA2_ROLE_LABEL,
+
+ /** A layered pane. A specialized pane that allows its children to be drawn
+ in layers, providing a form of stacking order. This is usually the pane that
+ holds the menu bar as well as the pane that contains most of the visual
+ components in a window.
+ Also refer to ::IA2_ROLE_CANVAS, ::IA2_ROLE_GLASS_PANE, and ::IA2_ROLE_ROOT_PANE.
+ */
+ IA2_ROLE_LAYERED_PANE,
+
+ /** A section whose content is parenthetic or ancillary to the main content
+ of the resource.
+ */
+ IA2_ROLE_NOTE,
+
+ /** A specialized pane whose primary use is inside a dialog.
+ Also refer to MSAA's dialog role.
+ */
+ IA2_ROLE_OPTION_PANE,
+
+ /** An object representing a page of document content. It is used in documents
+ which are accessed by the user on a page by page basis.
+ */
+ IA2_ROLE_PAGE,
+
+ /// A paragraph of text.
+ IA2_ROLE_PARAGRAPH,
+
+ /** A radio button that is a menu item.
+ Also refer to MSAA's button and menu item roles.
+ */
+ IA2_ROLE_RADIO_MENU_ITEM,
+
+ /** An object which is redundant with another object in the accessible hierarchy.
+ ATs typically ignore objects with this role.
+ */
+ IA2_ROLE_REDUNDANT_OBJECT,
+
+ /** A root pane. A specialized pane that has a glass pane and a layered pane
+ as its children.
+ Also refer to ::IA2_ROLE_GLASS_PANE and ::IA2_ROLE_LAYERED_PANE
+ */
+ IA2_ROLE_ROOT_PANE,
+
+ /** A ruler such as those used in word processors.
+ */
+ IA2_ROLE_RULER,
+
+ /** A scroll pane. An object that allows a user to incrementally view a large
+ amount of information. Its children can include scroll bars and a viewport.
+ Also refer to ::IA2_ROLE_VIEW_PORT and MSAA's scroll bar role.
+ */
+ IA2_ROLE_SCROLL_PANE,
+
+ /** A container of document content. An example of the use of this role is to
+ represent an HTML DIV tag. A section may be used as a region. A region is a
+ group of elements that together form a perceivable unit. A region does not
+ necessarily follow the logical structure of the content, but follows the
+ perceivable structure of the page. A region may have an attribute in the set
+ of IAccessible2::attributes which indicates that it is "live". A live region
+ is content that is likely to change in response to a timed change, a user
+ event, or some other programmed logic or event.
+ */
+ IA2_ROLE_SECTION,
+
+ /// Object with graphical representation used to represent content on draw pages.
+ IA2_ROLE_SHAPE,
+
+ /** A split pane. A specialized panel that presents two other panels at the
+ same time. Between the two panels is a divider the user can manipulate to make
+ one panel larger and the other panel smaller.
+ */
+ IA2_ROLE_SPLIT_PANE,
+
+ /** An object that forms part of a menu system but which can be "undocked"
+ from or "torn off" the menu system to exist as a separate window.
+ */
+ IA2_ROLE_TEAR_OFF_MENU,
+
+ /// An object used as a terminal emulator.
+ IA2_ROLE_TERMINAL,
+
+ /// Collection of objects that constitute a logical text entity.
+ IA2_ROLE_TEXT_FRAME,
+
+ /** A toggle button. A specialized push button that can be checked or unchecked,
+ but does not provide a separate indicator for the current state.
+ Also refer to MSAA's roles of push button, check box, and radio button.
+ <BR><B>Note:</B> IA2_ROLE_TOGGLE_BUTTON should not be used. Instead, use MSAA's
+ ROLE_SYSTEM_PUSHBUTTON and STATE_SYSTEM_PRESSED.
+ */
+ IA2_ROLE_TOGGLE_BUTTON,
+
+ /** A viewport. An object usually used in a scroll pane. It represents the
+ portion of the entire data that the user can see. As the user manipulates
+ the scroll bars, the contents of the viewport can change.
+ Also refer to ::IA2_ROLE_SCROLL_PANE.
+ */
+ IA2_ROLE_VIEW_PORT,
+
+ /** An object containing content which is complementary to the main content of
+ a document, but remains meaningful when separated from the main content. There
+ are various types of content that would appropriately have this role. For example,
+ in the case where content is delivered via a web portal to a web browser, this may
+ include but not be limited to show times, current weather, related articles, or
+ stocks to watch. The complementary role indicates that contained content is relevant
+ to the main content. If the complementary content is completely separable main
+ content, it may be appropriate to use a more general role.
+ */
+ IA2_ROLE_COMPLEMENTARY_CONTENT
+
+};
+
+const int NODETYPE_TEXT = 0;
+const int NODETYPE_DOCUMENT = 1;
+const int NODETYPE_ELEMENT = 1;
+
+enum IA2TextSpecialOffsets {
+ IA2_TEXT_OFFSET_LENGTH = -1, /**< This offset is equivalent to the length of the string. It eliminates
+ the need to call IAccessibleText::nCharacters. */
+ IA2_TEXT_OFFSET_CARET = -2 /**< This offset signifies that the text related to the physical location
+ of the caret should be used. */
+};
+/** The target object is the containing application object. */
+const WCHAR *const IA2_RELATION_CONTAINING_APPLICATION = L"containingApplication";
+
+/** The target object is the containing document object. The target object implements
+ the IAccessibleDocument interface.
+*/
+const WCHAR *const IA2_RELATION_CONTAINING_DOCUMENT = L"containingDocument";
+
+/** The target object is the containing tab pane object. */
+const WCHAR *const IA2_RELATION_CONTAINING_TAB_PANE = L"containingTabPane";
+
+/** The target object is the containing window object. */
+const WCHAR *const IA2_RELATION_CONTAINING_WINDOW = L"containingWindow";
+
+/** Some attribute of this object is affected by a target object. */
+const WCHAR *const IA2_RELATION_CONTROLLED_BY = L"controlledBy";
+
+/** This object is interactive and controls some attribute of a target object. */
+const WCHAR *const IA2_RELATION_CONTROLLER_FOR = L"controllerFor";
+
+/** This object is described by the target object. */
+const WCHAR *const IA2_RELATION_DESCRIBED_BY = L"describedBy";
+
+/** This object is describes the target object. */
+const WCHAR *const IA2_RELATION_DESCRIPTION_FOR = L"descriptionFor";
+
+/** This object is embedded by a target object. */
+const WCHAR *const IA2_RELATION_EMBEDDED_BY = L"embeddedBy";
+
+/** This object embeds a target object. This relation can be used on the
+ OBJID_CLIENT accessible for a top level window to show where the content
+ areas are.
+*/
+const WCHAR *const IA2_RELATION_EMBEDS = L"embeds";
+
+/** Content flows to this object from a target object.
+ This relation and IA2_RELATION_FLOWS_TO are useful to tie text and non-text
+ objects together in order to allow assistive technology to follow the
+ intended reading order.
+*/
+const WCHAR *const IA2_RELATION_FLOWS_FROM = L"flowsFrom";
+
+/** Content flows from this object to a target object. */
+const WCHAR *const IA2_RELATION_FLOWS_TO = L"flowsTo";
+
+/** This object is label for a target object. */
+const WCHAR *const IA2_RELATION_LABEL_FOR = L"labelFor";
+
+/** This object is labelled by a target object. Note that the double L spelling
+ which follows is preferred. Please use it instead. This single L version may
+ be removed in a later version.
+*/
+const WCHAR *const IA2_RELATION_LABELED_BY = L"labelledBy";
+
+/** This object is labelled by a target object. */
+const WCHAR *const IA2_RELATION_LABELLED_BY = L"labelledBy";
+
+/** This object is a member of a group of one or more objects. When
+ there is more than one object in the group each member may have one and the
+ same target, e.g. a grouping object. It is also possible that each member has
+ multiple additional targets, e.g. one for every other member in the group.
+*/
+const WCHAR *const IA2_RELATION_MEMBER_OF = L"memberOf";
+
+/** The target object is the next object in the tab order. */
+const WCHAR *const IA2_RELATION_NEXT_TABBABLE = L"nextTabbable";
+
+/** This object is a logical child of a target object. This relation is the reciprocal
+ of the IA2_RELATION_NODE_PARENT_OF relation. In some cases an application's accessible
+ tree is such that objects can be in a logical parent-child relationship which is
+ different from the hierarchy of the accessible tree. */
+const WCHAR *const IA2_RELATION_NODE_CHILD_OF = L"nodeChildOf";
+
+/** This object is a logical parent of a target object. This relation is the reciprocal
+ of the IA2_RELATION_NODE_CHILD_OF relation. In some cases an application's accessible
+ tree is such that objects can be in a logical parent-child relationship which is
+ different from the hierarchy of the accessible tree. */
+const WCHAR *const IA2_RELATION_NODE_PARENT_OF = L"nodeParentOf";
+
+/** This object is a parent window of the target object. */
+const WCHAR *const IA2_RELATION_PARENT_WINDOW_OF = L"parentWindowOf";
+
+/** This object is a transient component related to the target object.
+ When this object is activated the target object doesn't lose focus.
+*/
+const WCHAR *const IA2_RELATION_POPUP_FOR = L"popupFor";
+
+/** The target object is the previous object in the tab order. */
+const WCHAR *const IA2_RELATION_PREVIOUS_TABBABLE = L"previousTabbable";
+
+/** This object is a sub window of a target object. */
+const WCHAR *const IA2_RELATION_SUBWINDOW_OF = L"subwindowOf";
+enum IA2EventID {
+
+ /** The change of the number or attributes of actions of an accessible
+ object is signaled by events of this type.
+ */
+ IA2_EVENT_ACTION_CHANGED = 0x101,
+
+ /** <b>Deprecated.</b> The active descendant of a component has changed.
+
+ Note: This event constant is misspelled and thus is deprecated and will be
+ removed in a later version. Please use the correctly spelled version which
+ follows.
+ */
+ IA2_EVENT_ACTIVE_DECENDENT_CHANGED,
+
+ /** The active descendant of a component has changed. The active descendant
+ is used in objects with transient children.
+
+ Note: Due to the fact that MSAA's WinEvents don't allow the active child index
+ to be passed on the IA2_EVENT_ACTIVE_DESCENDANT_CHANGED event the manages
+ descendants scheme can't be used. Instead the active child object has to fire
+ MSAA's EVENT_OBJECT_FOCUS. In a future release a new event mechanism may be
+ added to provide for event specific data to be passed with the event. At that
+ time the IA2_EVENT_ACTIVE_DECENDENT_CHANGED event and
+ IA2_STATE_MANAGES_DESCENDANTS state would be useful.
+ */
+ IA2_EVENT_ACTIVE_DESCENDANT_CHANGED = IA2_EVENT_ACTIVE_DECENDENT_CHANGED,
+
+ /** The document wide attributes of the document object have changed.
+ */
+ IA2_EVENT_DOCUMENT_ATTRIBUTE_CHANGED,
+
+ /** The contents of the document have changed.
+ */
+ IA2_EVENT_DOCUMENT_CONTENT_CHANGED,
+
+ /** The loading of the document has completed.
+ */
+ IA2_EVENT_DOCUMENT_LOAD_COMPLETE,
+
+ /** The loading of the document was interrupted.
+ */
+ IA2_EVENT_DOCUMENT_LOAD_STOPPED,
+
+ /** The document contents are being reloaded.
+ */
+ IA2_EVENT_DOCUMENT_RELOAD,
+
+ /** The ending index of this link within the containing string has changed.
+ */
+ IA2_EVENT_HYPERLINK_END_INDEX_CHANGED,
+
+ /** The number of anchors associated with this hyperlink object has changed.
+ */
+ IA2_EVENT_HYPERLINK_NUMBER_OF_ANCHORS_CHANGED,
+
+ /** The hyperlink selected state changed from selected to unselected or
+ from unselected to selected.
+ */
+ IA2_EVENT_HYPERLINK_SELECTED_LINK_CHANGED,
+
+ /** One of the links associated with the hypertext object has been activated.
+ */
+ IA2_EVENT_HYPERTEXT_LINK_ACTIVATED,
+
+ /** One of the links associated with the hypertext object has been selected.
+ */
+ IA2_EVENT_HYPERTEXT_LINK_SELECTED,
+
+ /** The starting index of this link within the containing string has changed.
+ */
+ IA2_EVENT_HYPERLINK_START_INDEX_CHANGED,
+
+ /** Focus has changed from one hypertext object to another, or focus moved
+ from a non-hypertext object to a hypertext object, or focus moved from a
+ hypertext object to a non-hypertext object.
+ */
+ IA2_EVENT_HYPERTEXT_CHANGED,
+
+ /** The number of hyperlinks associated with a hypertext object changed
+ */
+ IA2_EVENT_HYPERTEXT_NLINKS_CHANGED,
+
+ /** An object's attributes changed.
+ Also see ::IA2_EVENT_TEXT_ATTRIBUTE_CHANGED.
+ */
+ IA2_EVENT_OBJECT_ATTRIBUTE_CHANGED,
+
+ /** A slide changed in a presentation document or a page boundary was
+ crossed in a word processing document.
+ */
+ IA2_EVENT_PAGE_CHANGED,
+
+ /** The caret moved from one section to the next.
+ */
+ IA2_EVENT_SECTION_CHANGED,
+
+ /** A table caption changed.
+ */
+ IA2_EVENT_TABLE_CAPTION_CHANGED,
+
+ /** A table's column description changed.
+ */
+ IA2_EVENT_TABLE_COLUMN_DESCRIPTION_CHANGED,
+
+ /** A table's column header changed.
+ */
+ IA2_EVENT_TABLE_COLUMN_HEADER_CHANGED,
+
+ /** A table's data changed.
+ */
+ IA2_EVENT_TABLE_MODEL_CHANGED,
+
+ /** A table's row description changed.
+ */
+ IA2_EVENT_TABLE_ROW_DESCRIPTION_CHANGED,
+
+ /** A table's row header changed.
+ */
+ IA2_EVENT_TABLE_ROW_HEADER_CHANGED,
+
+ /** A table's summary changed.
+ */
+ IA2_EVENT_TABLE_SUMMARY_CHANGED,
+
+ /** A text object's attributes changed.
+ Also see ::IA2_EVENT_OBJECT_ATTRIBUTE_CHANGED.
+ */
+ IA2_EVENT_TEXT_ATTRIBUTE_CHANGED,
+
+ /** The caret has moved to a new position.
+ */
+ IA2_EVENT_TEXT_CARET_MOVED,
+
+ /** <b>Deprecated.</b> This event is equivalent to ::IA2_EVENT_TEXT_UPDATED.
+ */
+ IA2_EVENT_TEXT_CHANGED,
+
+ /** The caret moved from one column to the next.
+ */
+ IA2_EVENT_TEXT_COLUMN_CHANGED,
+
+ /** Text was inserted.
+ */
+ IA2_EVENT_TEXT_INSERTED,
+
+ /** Text was removed.
+ */
+ IA2_EVENT_TEXT_REMOVED,
+
+ /** This event indicates general text changes, i.e. changes to text that are
+ exposed through the IAccessibleText interface. For compatibility with ATK/AT-SPI
+ which does not have an equivalent event, servers can alternatively fire
+ ::IA2_EVENT_TEXT_REMOVED and ::IA2_EVENT_TEXT_INSERTED.
+ */
+ IA2_EVENT_TEXT_UPDATED,
+
+ /** The text selection changed. Later versions of Microsoft development environments
+ have an equivalent event identified, EVENT_OBJECT_TEXTSELECTIONCHANGED. Servers
+ should use that if it is available and use IA2_EVENT_TEXT_SELECTION_CHANGED otherwise.
+ Clients should be prepared to respond to either event.
+
+ */
+ IA2_EVENT_TEXT_SELECTION_CHANGED,
+
+ /** A visible data event indicates the change of the visual appearance
+ of an accessible object. This includes for example most of the
+ attributes available via the IAccessibleComponent interface.
+ */
+ IA2_EVENT_VISIBLE_DATA_CHANGED
+
+};
+
+enum IA2CoordinateType {
+ IA2_COORDTYPE_SCREEN_RELATIVE,
+ IA2_COORDTYPE_PARENT_RELATIVE,
+};
+
+
+struct __declspec(uuid("00234000-0000-457b-a96d-07f000001000")) IAccessibleRelation {
+ virtual STDMETHODIMP get_relationType(BSTR* relation_type) {return S_OK;}
+ virtual STDMETHODIMP get_nTargets(long* n_targets) {return S_OK;}
+ virtual STDMETHODIMP get_target(long target_index, IUnknown** target) {return S_OK;}
+ virtual STDMETHODIMP get_targets(long max_targets, IUnknown** targets, long* n_targets) {return S_OK;}
+ virtual STDMETHODIMP get_localizedRelationType(BSTR* relation_type) {return S_OK;}
+};
+
+struct __declspec(uuid("00000000-0000-457b-a96d-07f000001000")) IAccessibleAction : public IUnknown {
+ virtual STDMETHODIMP nActions(long* n_actions) {return S_OK;}
+ virtual STDMETHODIMP doAction(long action_index) {return S_OK;}
+ virtual STDMETHODIMP get_description(long action_index, BSTR* description) {return S_OK;}
+ virtual STDMETHODIMP get_keyBinding(long action_index, long n_max_bindings, BSTR** key_bindings, long* n_bindings) {return S_OK;}
+ virtual STDMETHODIMP get_name(long action_index, BSTR* name) {return S_OK;}
+ virtual STDMETHODIMP get_localizedName(long action_index, BSTR* localized_name) {return S_OK;}
+};
+
+class __declspec(uuid("00000000-0000-457b-a96d-07f000000000")) IAccessibleText {
+public:
+ //
+ // IAccessibleText methods.
+ //
+
+ virtual STDMETHODIMP get_nCharacters(LONG* n_characters) {return S_OK;}
+
+ virtual STDMETHODIMP get_caretOffset(LONG* offset) {return S_OK;}
+
+ virtual STDMETHODIMP get_nSelections(LONG* n_selections) {return S_OK;}
+
+ virtual STDMETHODIMP get_selection(LONG selection_index, LONG* start_offset, LONG* end_offset) {return S_OK;}
+
+ virtual STDMETHODIMP get_text(LONG start_offset, LONG end_offset, BSTR* text) {return S_OK;}
+
+ virtual STDMETHODIMP get_textAtOffset(LONG offset, enum IA2TextBoundaryType boundary_type, LONG* start_offset, LONG* end_offset, BSTR* text) {return S_OK;}
+
+ virtual STDMETHODIMP get_textBeforeOffset(LONG offset, enum IA2TextBoundaryType boundary_type, LONG* start_offset, LONG* end_offset, BSTR* text) {return S_OK;}
+
+ virtual STDMETHODIMP get_textAfterOffset(LONG offset, enum IA2TextBoundaryType boundary_type, LONG* start_offset, LONG* end_offset, BSTR* text) {return S_OK;}
+
+ virtual STDMETHODIMP get_offsetAtPoint(LONG x, LONG y, enum IA2CoordinateType coord_type, LONG* offset) {return S_OK;}
+
+ //
+ // IAccessibleText methods not implemented.
+ //
+
+ virtual STDMETHODIMP get_newText(IA2TextSegment* new_text) {return S_OK;}
+ virtual STDMETHODIMP get_oldText(IA2TextSegment* old_text) {return S_OK;}
+ virtual STDMETHODIMP addSelection(LONG start_offset, LONG end_offset) {return S_OK;}
+ virtual STDMETHODIMP get_attributes(LONG offset, LONG* start_offset, LONG* end_offset, BSTR* text_attributes) {return S_OK;}
+ virtual STDMETHODIMP get_characterExtents(LONG offset, enum IA2CoordinateType coord_type, LONG* x, LONG* y, LONG* width, LONG* height) {return S_OK;}
+ virtual STDMETHODIMP removeSelection(LONG selection_index) {return S_OK;}
+ virtual STDMETHODIMP setCaretOffset(LONG offset) {return S_OK;}
+ virtual STDMETHODIMP setSelection(LONG selection_index, LONG start_offset, LONG end_offset) {return S_OK;}
+ virtual STDMETHODIMP scrollSubstringTo(LONG start_index, LONG end_index, enum IA2ScrollType scroll_type) {return S_OK;}
+ virtual STDMETHODIMP scrollSubstringToPoint(LONG start_index, LONG end_index, enum IA2CoordinateType coordinate_type, LONG x, LONG y) {return S_OK;}
+};
+
+struct __declspec(uuid("26f5641a-246d-457b-a96d-07f000000000")) IAccessible2 : public IAccessible {
+ // Returns role from a longer list of possible roles.
+ virtual STDMETHODIMP role(LONG* role) {return S_OK;}
+
+ // Returns the state bitmask from a larger set of possible states.
+ virtual STDMETHODIMP get_states(AccessibleStates* states) {return S_OK;}
+
+ // Returns the attributes specific to this IAccessible2 object,
+ // such as a cell's formula.
+ virtual STDMETHODIMP get_attributes(BSTR* attributes) {return S_OK;}
+
+ // Get the unique ID of this object so that the client knows if it's
+ // been encountered previously.
+ virtual STDMETHODIMP get_uniqueID(LONG* unique_id) {return S_OK;}
+
+ // Get the window handle of the enclosing window.
+ virtual STDMETHODIMP get_windowHandle(HWND* window_handle) {return S_OK;}
+
+ // Get this object's index in its parent object.
+ virtual STDMETHODIMP get_indexInParent(LONG* index_in_parent) {return S_OK;}
+
+ virtual STDMETHODIMP get_nRelations(LONG* n_relations) {return S_OK;}
+
+ STDMETHODIMP
+ virtual get_relation(LONG relation_index, IAccessibleRelation** relation) {return S_OK;}
+
+ virtual STDMETHODIMP get_relations(LONG max_relations, IAccessibleRelation** relations, LONG* n_relations) {return S_OK;}
+
+ virtual STDMETHODIMP scrollTo(enum IA2ScrollType scroll_type) {return S_OK;}
+
+ virtual STDMETHODIMP scrollToPoint(enum IA2CoordinateType coordinate_type, LONG x, LONG y) {return S_OK;}
+
+ virtual STDMETHODIMP get_groupPosition(LONG* group_level, LONG* similar_items_in_group, LONG* position_in_group) {return S_OK;}
+
+ virtual STDMETHODIMP get_extendedRole(BSTR* extended_role) {return S_OK;}
+ virtual STDMETHODIMP get_localizedExtendedRole(BSTR* localized_extended_role) {return S_OK;}
+ virtual STDMETHODIMP get_nExtendedStates(LONG* n_extended_states) {return S_OK;}
+ virtual STDMETHODIMP get_extendedStates(LONG max_extended_states, BSTR** extended_states, LONG* n_extended_states) {return S_OK;}
+ virtual STDMETHODIMP get_localizedExtendedStates(LONG max_localized_extended_states, BSTR** localized_extended_states, LONG* n_localized_extended_states) {return S_OK;}
+ virtual STDMETHODIMP get_locale(IA2Locale* locale) {return S_OK;}
+};
+
+class __declspec(uuid("00000000-246d-457b-a96d-07f000000000")) IAccessible2_2 : public IAccessible2 {
+ public:
+ //
+ // IAccessible methods.
+ //
+
+ // Retrieves the child element or child object at a given point on the screen.
+ virtual STDMETHODIMP accHitTest(LONG x_left, LONG y_top, VARIANT* child) {return S_OK;}
+
+ // Performs the object's default action.
+ virtual STDMETHODIMP accDoDefaultAction(VARIANT var_id) {return S_OK;}
+
+ // Retrieves the specified object's current screen location.
+ virtual STDMETHODIMP accLocation(LONG* x_left, LONG* y_top, LONG* width, LONG* height, VARIANT var_id) {return S_OK;}
+
+ // Traverses to another UI element and retrieves the object.
+ virtual STDMETHODIMP accNavigate(LONG nav_dir, VARIANT start, VARIANT* end) {return S_OK;}
+
+ // Retrieves an IDispatch interface pointer for the specified child.
+ virtual STDMETHODIMP get_accChild(VARIANT var_child, IDispatch** disp_child) {return S_OK;}
+
+ // Retrieves the number of accessible children.
+ virtual STDMETHODIMP get_accChildCount(LONG* child_count) {return S_OK;}
+
+ // Retrieves a string that describes the object's default action.
+ virtual STDMETHODIMP get_accDefaultAction(VARIANT var_id, BSTR* default_action) {return S_OK;}
+
+ // Retrieves the tooltip description.
+ virtual STDMETHODIMP get_accDescription(VARIANT var_id, BSTR* desc) {return S_OK;}
+
+ // Retrieves the object that has the keyboard focus.
+ virtual STDMETHODIMP get_accFocus(VARIANT* focus_child) {return S_OK;}
+
+ // Retrieves the specified object's shortcut.
+ virtual STDMETHODIMP get_accKeyboardShortcut(VARIANT var_id, BSTR* access_key) {return S_OK;}
+
+ // Retrieves the name of the specified object.
+ virtual STDMETHODIMP get_accName(VARIANT var_id, BSTR* name) {return S_OK;}
+
+ // Retrieves the IDispatch interface of the object's parent.
+ virtual STDMETHODIMP get_accParent(IDispatch** disp_parent) {return S_OK;}
+
+ // Retrieves information describing the role of the specified object.
+ virtual STDMETHODIMP get_accRole(VARIANT var_id, VARIANT* role) {return S_OK;}
+
+ // Retrieves the current state of the specified object.
+ virtual STDMETHODIMP get_accState(VARIANT var_id, VARIANT* state) {return S_OK;}
+
+ // Gets the help string for the specified object.
+ virtual STDMETHODIMP get_accHelp(VARIANT var_id, BSTR* help) {return S_OK;}
+
+ // Retrieve or set the string value associated with the specified object.
+ // Setting the value is not typically used by screen readers, but it's
+ // used frequently by automation software.
+ virtual STDMETHODIMP get_accValue(VARIANT var_id, BSTR* value) {return S_OK;}
+ virtual STDMETHODIMP put_accValue(VARIANT var_id, BSTR new_value) {return S_OK;}
+
+ // IAccessible methods not implemented.
+ virtual STDMETHODIMP get_accSelection(VARIANT* selected) {return S_OK;}
+ virtual STDMETHODIMP accSelect(LONG flags_sel, VARIANT var_id) {return S_OK;}
+ virtual STDMETHODIMP get_accHelpTopic(BSTR* help_file, VARIANT var_id, LONG* topic_id) {return S_OK;}
+ virtual STDMETHODIMP put_accName(VARIANT var_id, BSTR put_name) {return S_OK;}
+
+ //
+ // IAccessible2 methods.
+ //
+
+ virtual STDMETHODIMP role(LONG* role) {return S_OK;}
+
+ virtual STDMETHODIMP get_states(AccessibleStates* states) {return S_OK;}
+
+ virtual STDMETHODIMP get_uniqueID(LONG* unique_id) {return S_OK;}
+
+ virtual STDMETHODIMP get_windowHandle(HWND* window_handle) {return S_OK;}
+
+ virtual STDMETHODIMP get_relationTargetsOfType(BSTR type, long max_targets, IUnknown*** targets, long* n_targets) {return S_OK;}
+
+ virtual STDMETHODIMP get_attributes(BSTR* attributes) {return S_OK;}
+
+ virtual STDMETHODIMP get_indexInParent(LONG* index_in_parent) {return S_OK;}
+
+ //
+ // IAccessible2 methods not implemented.
+ //
+
+ virtual STDMETHODIMP get_attribute(BSTR name, VARIANT* attribute) {return S_OK;}
+ virtual STDMETHODIMP get_extendedRole(BSTR* extended_role) {return S_OK;}
+ virtual STDMETHODIMP get_nRelations(LONG* n_relations) {return S_OK;}
+ virtual STDMETHODIMP get_relation(LONG relation_index, IAccessibleRelation** relation) {return S_OK;}
+ virtual STDMETHODIMP get_relations(LONG max_relations, IAccessibleRelation** relations, LONG* n_relations) {return S_OK;}
+ virtual STDMETHODIMP scrollTo(enum IA2ScrollType scroll_type) {return S_OK;}
+ virtual STDMETHODIMP scrollToPoint(enum IA2CoordinateType coordinate_type, LONG x, LONG y) {return S_OK;}
+ virtual STDMETHODIMP get_groupPosition(LONG* group_level, LONG* similar_items_in_group, LONG* position_in_group) {return S_OK;}
+ virtual STDMETHODIMP get_localizedExtendedRole( BSTR* localized_extended_role) {return S_OK;}
+ virtual STDMETHODIMP get_nExtendedStates(LONG* n_extended_states) {return S_OK;}
+ virtual STDMETHODIMP get_extendedStates(LONG max_extended_states, BSTR** extended_states, LONG* n_extended_states) {return S_OK;}
+ virtual STDMETHODIMP get_localizedExtendedStates( LONG max_localized_extended_states, BSTR** localized_extended_states, LONG* n_localized_extended_states) {return S_OK;}
+ virtual STDMETHODIMP get_locale(IA2Locale* locale) {return S_OK;}
+ virtual STDMETHODIMP get_accessibleWithCaret(IUnknown** accessible, long* caret_offset) {return S_OK;}
+};
+
+struct __declspec(uuid("00000000-0000-457b-a96d-07f000001008")) IAccessibleApplication {
+ virtual STDMETHODIMP get_appName(BSTR* app_name) {return S_OK;}
+
+ virtual STDMETHODIMP get_appVersion(BSTR* app_version) {return S_OK;}
+
+ virtual STDMETHODIMP get_toolkitName(BSTR* toolkit_name) {return S_OK;}
+
+ virtual STDMETHODIMP get_toolkitVersion(BSTR* toolkit_version) {return S_OK;}
+};
+
+struct __declspec(uuid("00000000-0000-457b-a96d-07f000001028")) IAccessibleHyperlink : public IAccessibleAction {
+ virtual STDMETHODIMP get_anchor(long index, VARIANT* anchor) {return S_OK;}
+ virtual STDMETHODIMP get_anchorTarget(long index, VARIANT* anchor_target) {return S_OK;}
+ virtual STDMETHODIMP get_startIndex(long* index) {return S_OK;}
+ virtual STDMETHODIMP get_endIndex(long* index) {return S_OK;}
+ virtual STDMETHODIMP get_valid(boolean* valid) {return S_OK;}
+};
+
+struct __declspec(uuid("00000000-0000-457b-a96d-07f000001038")) IAccessibleHypertext : public IAccessibleText {
+ virtual STDMETHODIMP get_nHyperlinks(long* hyperlink_count) {return S_OK;}
+
+ virtual STDMETHODIMP get_hyperlink(long index, IAccessibleHyperlink** hyperlink) {return S_OK;}
+
+ virtual STDMETHODIMP get_hyperlinkIndex(long char_index, long* hyperlink_index) {return S_OK;}
+};
+
+struct __declspec(uuid("00000000-0000-457b-a96d-07f002001008")) IAccessibleImage {
+ virtual STDMETHODIMP get_description(BSTR* description) {return S_OK;}
+
+ virtual STDMETHODIMP get_imagePosition(enum IA2CoordinateType coordinate_type, LONG* x, LONG* y) {return S_OK;}
+
+ virtual STDMETHODIMP get_imageSize(LONG* height, LONG* width) {return S_OK;}
+};
+
+struct __declspec(uuid("00000000-0000-450b-a96d-07f002001008")) IAccessibleTable : public IUnknown {
+ virtual STDMETHODIMP get_accessibleAt(long row, long column, IUnknown** accessible) {return S_OK;}
+
+ virtual STDMETHODIMP get_caption(IUnknown** accessible) {return S_OK;}
+
+ virtual STDMETHODIMP get_childIndex(long row_index, long column_index, long* cell_index) {return S_OK;}
+
+ virtual STDMETHODIMP get_columnDescription(long column, BSTR* description) {return S_OK;}
+
+ virtual STDMETHODIMP get_columnExtentAt(long row, long column, long* n_columns_spanned) {return S_OK;}
+
+ virtual STDMETHODIMP get_columnHeader(IAccessibleTable** accessible_table, long* starting_row_index) {return S_OK;}
+
+ virtual STDMETHODIMP get_columnIndex(long cell_index, long* column_index) {return S_OK;}
+
+ virtual STDMETHODIMP get_nColumns(long* column_count) {return S_OK;}
+ virtual STDMETHODIMP get_nRows(long* row_count) {return S_OK;}
+
+ virtual STDMETHODIMP get_nSelectedChildren(long* cell_count) {return S_OK;}
+
+ virtual STDMETHODIMP get_nSelectedColumns(long* column_count) {return S_OK;}
+
+ virtual STDMETHODIMP get_nSelectedRows(long* row_count) {return S_OK;}
+
+ virtual STDMETHODIMP get_rowDescription(long row, BSTR* description) {return S_OK;}
+
+ virtual STDMETHODIMP get_rowExtentAt(long row, long column, long* n_rows_spanned) {return S_OK;}
+
+ virtual STDMETHODIMP get_rowHeader(IAccessibleTable** accessible_table, long* starting_column_index) {return S_OK;}
+
+ virtual STDMETHODIMP get_rowIndex(long cell_index, long* row_index) {return S_OK;}
+
+ virtual STDMETHODIMP get_selectedChildren(long max_children, long** children, long* n_children) {return S_OK;}
+ virtual STDMETHODIMP get_selectedColumns(long max_columns, long** columns, long* n_columns) {return S_OK;}
+
+ virtual STDMETHODIMP get_selectedRows(long max_rows, long** rows, long* n_rows) {return S_OK;}
+
+ virtual STDMETHODIMP get_summary(IUnknown** accessible) {return S_OK;}
+
+ virtual STDMETHODIMP get_isColumnSelected(long column, boolean* is_selected) {return S_OK;}
+
+ virtual STDMETHODIMP get_isRowSelected(long row, boolean* is_selected) {return S_OK;}
+
+ virtual STDMETHODIMP get_isSelected(long row, long column, boolean* is_selected) {return S_OK;}
+
+ virtual STDMETHODIMP get_rowColumnExtentsAtIndex(long index, long* row, long* column, long* row_extents, long* column_extents, boolean* is_selected) {return S_OK;}
+
+ virtual STDMETHODIMP selectRow(long row) {return S_OK;}
+ virtual STDMETHODIMP selectColumn(long column) {return S_OK;}
+
+ virtual STDMETHODIMP unselectRow(long row) {return S_OK;}
+
+ virtual STDMETHODIMP unselectColumn(long column) {return S_OK;}
+
+ virtual STDMETHODIMP get_modelChange(IA2TableModelChange* model_change) {return S_OK;}
+};
+
+struct __declspec(uuid("00100000-0000-450b-a96d-07f002001008")) IAccessibleTable2 {
+ virtual STDMETHODIMP get_cellAt(long row, long column, IUnknown** cell) {return S_OK;}
+ virtual STDMETHODIMP get_nSelectedCells(long* cell_count) {return S_OK;}
+ virtual STDMETHODIMP get_selectedCells(IUnknown*** cells, long* n_selected_cells) {return S_OK;}
+ virtual STDMETHODIMP get_selectedColumns(long** columns, long* n_columns) {return S_OK;}
+ virtual STDMETHODIMP get_selectedRows(long** rows, long* n_rows) {return S_OK;}
+};
+
+struct __declspec(uuid("00100001-0000-450b-a96d-07f002001008")) IAccessibleTableCell {
+ virtual STDMETHODIMP get_columnExtent(long* n_columns_spanned) {return S_OK;}
+
+ virtual STDMETHODIMP get_columnHeaderCells(IUnknown*** cell_accessibles, long* n_column_header_cells) {return S_OK;}
+
+ virtual STDMETHODIMP get_columnIndex(long* column_index) {return S_OK;}
+
+ virtual STDMETHODIMP get_rowExtent(long* n_rows_spanned) {return S_OK;}
+
+ virtual STDMETHODIMP get_rowHeaderCells(IUnknown*** cell_accessibles, long* n_row_header_cells) {return S_OK;}
+
+ virtual STDMETHODIMP get_rowIndex(long* row_index) {return S_OK;}
+
+ virtual STDMETHODIMP get_isSelected(boolean* is_selected) {return S_OK;}
+
+ virtual STDMETHODIMP get_rowColumnExtents(long* row, long* column, long* row_extents, long* column_extents, boolean* is_selected) {return S_OK;}
+
+ virtual STDMETHODIMP get_table(IUnknown** table) {return S_OK;}
+};
+
+struct __declspec(uuid("00100001-0000-450b-a97d-07f002001008")) IAccessibleValue {
+ virtual STDMETHODIMP get_currentValue(VARIANT* value) {return S_OK;}
+
+ virtual STDMETHODIMP get_minimumValue(VARIANT* value) {return S_OK;}
+
+ virtual STDMETHODIMP get_maximumValue(VARIANT* value) {return S_OK;}
+
+ virtual STDMETHODIMP setCurrentValue(VARIANT new_value) {return S_OK;}
+};
+
+//struct IServiceProvider { };
+struct __declspec(uuid("00100001-0010-451b-a97d-07f002001008")) ISimpleDOMDocument {
+ virtual STDMETHODIMP get_URL(BSTR* url) {return S_OK;}
+
+ virtual STDMETHODIMP get_title(BSTR* title) {return S_OK;}
+
+ virtual STDMETHODIMP get_mimeType(BSTR* mime_type) {return S_OK;}
+
+ virtual STDMETHODIMP get_docType(BSTR* doc_type) {return S_OK;}
+
+ virtual STDMETHODIMP get_nameSpaceURIForID(short name_space_id, BSTR* name_space_uri) {return S_OK;}
+ virtual STDMETHODIMP put_alternateViewMediaTypes(BSTR* comma_separated_media_types) {return S_OK;}
+
+};
+
+struct __declspec(uuid("00100001-0010-151b-a97d-07f002001008")) ISimpleDOMNode {
+ virtual STDMETHODIMP get_nodeInfo(BSTR* node_name, short* name_space_id, BSTR* node_value, unsigned int* num_children, unsigned int* unique_id, unsigned short* node_type) {return S_OK;}
+
+ virtual STDMETHODIMP get_attributes(unsigned short max_attribs, BSTR* attrib_names, short* name_space_id, BSTR* attrib_values, unsigned short* num_attribs) {return S_OK;}
+
+ virtual STDMETHODIMP get_attributesForNames(unsigned short num_attribs, BSTR* attrib_names, short* name_space_id, BSTR* attrib_values) {return S_OK;}
+
+ virtual STDMETHODIMP get_computedStyle(unsigned short max_style_properties, boolean use_alternate_view, BSTR* style_properties, BSTR* style_values, unsigned short* num_style_properties) {return S_OK;}
+
+ virtual STDMETHODIMP get_computedStyleForProperties(unsigned short num_style_properties, boolean use_alternate_view, BSTR* style_properties, BSTR* style_values) {return S_OK;}
+
+ virtual STDMETHODIMP scrollTo(boolean placeTopLeft) {return S_OK;}
+
+ virtual STDMETHODIMP get_parentNode(ISimpleDOMNode** node) {return S_OK;}
+
+ virtual STDMETHODIMP get_firstChild(ISimpleDOMNode** node) {return S_OK;}
+
+ virtual STDMETHODIMP get_lastChild(ISimpleDOMNode** node) {return S_OK;}
+
+ virtual STDMETHODIMP get_previousSibling(ISimpleDOMNode** node) {return S_OK;}
+
+ virtual STDMETHODIMP get_nextSibling(ISimpleDOMNode** node) {return S_OK;}
+
+ virtual STDMETHODIMP get_childAt(unsigned int child_index, ISimpleDOMNode** node) {return S_OK;}
+
+ virtual STDMETHODIMP get_innerHTML(BSTR* innerHTML) {return S_OK;}
+
+ virtual STDMETHODIMP get_localInterface(void** local_interface) {return S_OK;}
+
+ virtual STDMETHODIMP get_language(BSTR* language) {return S_OK;}
+};
+
+struct __declspec(uuid("00100001-1010-151b-a97d-07f002001008")) ISimpleDOMText {
+ virtual STDMETHODIMP get_domText(BSTR* dom_text) {return S_OK;}
+
+ virtual STDMETHODIMP get_clippedSubstringBounds(unsigned int start_index, unsigned int end_index, int* out_x, int* out_y, int* out_width, int* out_height) {return S_OK;}
+
+ virtual STDMETHODIMP get_unclippedSubstringBounds(unsigned int start_index, unsigned int end_index, int* out_x, int* out_y, int* out_width, int* out_height) {return S_OK;}
+
+ virtual STDMETHODIMP scrollToSubstring(unsigned int start_index, unsigned int end_index) {return S_OK;}
+
+ virtual STDMETHODIMP get_fontFamily(BSTR* font_family) {return S_OK;}
+};
+
+//struct IAccessibleEx { };
+//struct IRawElementProviderSimple { };
+
+#endif
« no previous file with comments | « content/browser/accessibility/browser_accessibility_win.h ('k') | ppapi/tests/ppapi_nacl_tests_newlib.nmf » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698