mirror of
https://github.com/roytam1/palemoon27.git
synced 2026-05-26 14:18:48 +00:00
04083ef9b4
- Bug 1235261 - Part 1: Rename nsAutoTArray to AutoTArray. r=froydnj (0662c2ac56)
- Bug 1235261 - Part 2: Switch some uses of AutoFallibleTArray to AutoTArray. r=froydnj (ab52085f2a)
- Bug 1235261 - Part 3: Switch remaining uses of AutoFallibleTArray to AutoTArray. r=froydnj (3763b16ddd)
- Bug 1235261 - Part 4: Remove AutoFallibleTArray. r=froydnj (5480b0d786)
- Bug 1235261 - Part 5: Merge nsAutoArrayBase into AutoTArray. r=froydnj (6c64e73e3b)
- Bug 1235261 - Part 7: Remove AutoInfallibleTArray. r=froydnj (acf266464e)
- Bug 1222624: Make xpath document() function use nsIPrincipals and nsIURIs rather than strings. r=peterv (5ee694d132)
- Bug 1235261 - Part 6: Rename AutoInfallibleTArray to AutoTArray. r=froydnj (d282f7df6c)
- Bug 1241394 - Hit testing with 3d transforms should use fuzzy when comparing depths. r=thinker (6c3f50670f)
- Bug 1241394 - Follow up to fix windows build bustage. (02ab2600af)
- Bug 1241394 - Check clip for the children of the establisher. r=mattwoodrow (46f151ea55)
- bug 1241453 - allow caching proxies in xpcAccessibleDocuments r=davidb (f5d41ad2ee)
- Bug 1247364 - use AllChildrenIterator::Seek by a11y tree walker, r=davidb (0ec230908e)
- Bug 1248840 - rename TreeWalker::NextChild, r=yzen (c89ecc5a29)
- Bug 1249927 - devirtualize CanHavaAnonymousChildren, r=davdib (89e8088e63)
- Bug 1206598 - Use universal reference to reduce the redundant copy. r=nfroyd (bae4ad6dd1)
- Bug 1247364 - add AllChildrenIterator::Seek, r=bz (215abebf12)
- bug 1241453 - allow storing proxies in xpcAccessibleGeneric::mIntl r=davidb (dd5e6c896b)
- bug 1241453 - allow constructing xpcAccessibles with proxies r=davidb (d0258122be)
- bug 1241453 - fixup xpcAccessible Intl() methods to not assume mIntl is always an Accessible r=davidb (168f71fdf5)
- bug 1241453 - allow xpcAccessibleDocument::mCache to use proxies as keys r=davidb (85b7eec81c)
- bug 1241453 - assert accessibles are only added to non remote xpcAccessibleDocuments r=davidb (7731b21d17)
- bug 1243077 - add ToXPC{,Document} overloads for proxied accessibles r=davidb (7bc085f1b5)
- bug 1243077 - add AccessibleOrProxy xpcAccessible::IntlGeneric() r=davidb (006a635992)
- Bug 1245464 - initialize with 0 mSupportedIfaces in xpcAccessibleGeneric in order to avoid corrupted result after bit-wise operation. r=surkov (ae41bafcef)
- bug 1241453 - allow caching xpc documents for remote documents r=davidb (a357630690)
- bug 1241453 - factor dispatching nsIAccessibleEvents out of HandleAccEvent() r=davidb (091073d981)
- Bug 1249183 - Suppress GC harder, r=terrence (2185ccb4dd)
- Bug 1248420 - Handle JSObject::getGroup OOM in js::ArraySetLength. r=jandem (04b67c8d31)
- Bug 1242270 - Add SPS pseudo frames for the Array.prototype methods; r=shu (f5e5871439)
- Bug 1247701 - Bail from ArrayShiftDenseKernel if the array is used by for-in iteration. r=jandem (41eff38954)
- Bug 1247701 followup - Change ArrayShiftDenseKernel to receive handle. r=bz (b29ce0c555)
641 lines
17 KiB
C++
641 lines
17 KiB
C++
/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
|
|
/* vim:expandtab:shiftwidth=2:tabstop=2:
|
|
*/
|
|
/* This Source Code Form is subject to the terms of the Mozilla Public
|
|
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
|
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
|
|
|
|
#include "ia2AccessibleText.h"
|
|
|
|
#include "Accessible2.h"
|
|
#include "AccessibleText_i.c"
|
|
|
|
#include "HyperTextAccessibleWrap.h"
|
|
#include "HyperTextAccessible-inl.h"
|
|
#include "ProxyWrappers.h"
|
|
#include "mozilla/ClearOnShutdown.h"
|
|
|
|
using namespace mozilla::a11y;
|
|
|
|
StaticRefPtr<HyperTextAccessibleWrap> ia2AccessibleText::sLastTextChangeAcc;
|
|
StaticAutoPtr<nsString> ia2AccessibleText::sLastTextChangeString;
|
|
uint32_t ia2AccessibleText::sLastTextChangeStart = 0;
|
|
uint32_t ia2AccessibleText::sLastTextChangeEnd = 0;
|
|
bool ia2AccessibleText::sLastTextChangeWasInsert = false;
|
|
|
|
// IAccessibleText
|
|
|
|
STDMETHODIMP
|
|
ia2AccessibleText::addSelection(long aStartOffset, long aEndOffset)
|
|
{
|
|
A11Y_TRYBLOCK_BEGIN
|
|
|
|
if (ProxyAccessible* proxy = HyperTextProxyFor(this)) {
|
|
return proxy->AddToSelection(aStartOffset, aEndOffset) ?
|
|
S_OK : E_INVALIDARG;
|
|
}
|
|
|
|
HyperTextAccessible* textAcc = static_cast<HyperTextAccessibleWrap*>(this);
|
|
if (textAcc->IsDefunct())
|
|
return CO_E_OBJNOTCONNECTED;
|
|
|
|
return textAcc->AddToSelection(aStartOffset, aEndOffset) ?
|
|
S_OK : E_INVALIDARG;
|
|
|
|
A11Y_TRYBLOCK_END
|
|
}
|
|
|
|
STDMETHODIMP
|
|
ia2AccessibleText::get_attributes(long aOffset, long *aStartOffset,
|
|
long *aEndOffset, BSTR *aTextAttributes)
|
|
{
|
|
A11Y_TRYBLOCK_BEGIN
|
|
|
|
if (!aStartOffset || !aEndOffset || !aTextAttributes)
|
|
return E_INVALIDARG;
|
|
|
|
*aStartOffset = 0;
|
|
*aEndOffset = 0;
|
|
*aTextAttributes = nullptr;
|
|
|
|
int32_t startOffset = 0, endOffset = 0;
|
|
HRESULT hr;
|
|
if (ProxyAccessible* proxy = HyperTextProxyFor(this)) {
|
|
AutoTArray<Attribute, 10> attrs;
|
|
proxy->TextAttributes(true, aOffset, &attrs, &startOffset, &endOffset);
|
|
hr = AccessibleWrap::ConvertToIA2Attributes(&attrs, aTextAttributes);
|
|
} else {
|
|
HyperTextAccessible* textAcc = static_cast<HyperTextAccessibleWrap*>(this);
|
|
if (textAcc->IsDefunct())
|
|
return CO_E_OBJNOTCONNECTED;
|
|
|
|
nsCOMPtr<nsIPersistentProperties> attributes =
|
|
textAcc->TextAttributes(true, aOffset, &startOffset, &endOffset);
|
|
|
|
hr = AccessibleWrap::ConvertToIA2Attributes(attributes, aTextAttributes);
|
|
}
|
|
|
|
if (FAILED(hr))
|
|
return hr;
|
|
|
|
*aStartOffset = startOffset;
|
|
*aEndOffset = endOffset;
|
|
|
|
return S_OK;
|
|
|
|
A11Y_TRYBLOCK_END
|
|
}
|
|
|
|
STDMETHODIMP
|
|
ia2AccessibleText::get_caretOffset(long *aOffset)
|
|
{
|
|
A11Y_TRYBLOCK_BEGIN
|
|
|
|
if (!aOffset)
|
|
return E_INVALIDARG;
|
|
|
|
*aOffset = -1;
|
|
|
|
if (ProxyAccessible* proxy = HyperTextProxyFor(this)) {
|
|
*aOffset = proxy->CaretOffset();
|
|
} else {
|
|
HyperTextAccessible* textAcc = static_cast<HyperTextAccessibleWrap*>(this);
|
|
if (textAcc->IsDefunct())
|
|
return CO_E_OBJNOTCONNECTED;
|
|
|
|
*aOffset = textAcc->CaretOffset();
|
|
}
|
|
|
|
return *aOffset != -1 ? S_OK : S_FALSE;
|
|
|
|
A11Y_TRYBLOCK_END
|
|
}
|
|
|
|
STDMETHODIMP
|
|
ia2AccessibleText::get_characterExtents(long aOffset,
|
|
enum IA2CoordinateType aCoordType,
|
|
long* aX, long* aY,
|
|
long* aWidth, long* aHeight)
|
|
{
|
|
A11Y_TRYBLOCK_BEGIN
|
|
|
|
if (!aX || !aY || !aWidth || !aHeight)
|
|
return E_INVALIDARG;
|
|
*aX = *aY = *aWidth = *aHeight = 0;
|
|
|
|
uint32_t geckoCoordType = (aCoordType == IA2_COORDTYPE_SCREEN_RELATIVE) ?
|
|
nsIAccessibleCoordinateType::COORDTYPE_SCREEN_RELATIVE :
|
|
nsIAccessibleCoordinateType::COORDTYPE_PARENT_RELATIVE;
|
|
nsIntRect rect;
|
|
if (ProxyAccessible* proxy = HyperTextProxyFor(this)) {
|
|
rect = proxy->CharBounds(aOffset, geckoCoordType);
|
|
} else {
|
|
HyperTextAccessible* textAcc = static_cast<HyperTextAccessibleWrap*>(this);
|
|
if (textAcc->IsDefunct())
|
|
return CO_E_OBJNOTCONNECTED;
|
|
|
|
rect = textAcc->CharBounds(aOffset, geckoCoordType);
|
|
}
|
|
|
|
*aX = rect.x;
|
|
*aY = rect.y;
|
|
*aWidth = rect.width;
|
|
*aHeight = rect.height;
|
|
return S_OK;
|
|
|
|
A11Y_TRYBLOCK_END
|
|
}
|
|
|
|
STDMETHODIMP
|
|
ia2AccessibleText::get_nSelections(long* aNSelections)
|
|
{
|
|
A11Y_TRYBLOCK_BEGIN
|
|
|
|
if (!aNSelections)
|
|
return E_INVALIDARG;
|
|
*aNSelections = 0;
|
|
|
|
if (ProxyAccessible* proxy = HyperTextProxyFor(this)) {
|
|
*aNSelections = proxy->SelectionCount();
|
|
} else {
|
|
HyperTextAccessible* textAcc = static_cast<HyperTextAccessibleWrap*>(this);
|
|
if (textAcc->IsDefunct())
|
|
return CO_E_OBJNOTCONNECTED;
|
|
|
|
*aNSelections = textAcc->SelectionCount();
|
|
}
|
|
|
|
return S_OK;
|
|
|
|
A11Y_TRYBLOCK_END
|
|
}
|
|
|
|
STDMETHODIMP
|
|
ia2AccessibleText::get_offsetAtPoint(long aX, long aY,
|
|
enum IA2CoordinateType aCoordType,
|
|
long* aOffset)
|
|
{
|
|
A11Y_TRYBLOCK_BEGIN
|
|
|
|
if (!aOffset)
|
|
return E_INVALIDARG;
|
|
*aOffset = 0;
|
|
|
|
uint32_t geckoCoordType = (aCoordType == IA2_COORDTYPE_SCREEN_RELATIVE) ?
|
|
nsIAccessibleCoordinateType::COORDTYPE_SCREEN_RELATIVE :
|
|
nsIAccessibleCoordinateType::COORDTYPE_PARENT_RELATIVE;
|
|
|
|
if (ProxyAccessible* proxy = HyperTextProxyFor(this)) {
|
|
*aOffset = proxy->OffsetAtPoint(aX, aY, geckoCoordType);
|
|
} else {
|
|
HyperTextAccessible* textAcc = static_cast<HyperTextAccessibleWrap*>(this);
|
|
if (textAcc->IsDefunct())
|
|
return CO_E_OBJNOTCONNECTED;
|
|
|
|
*aOffset = textAcc->OffsetAtPoint(aX, aY, geckoCoordType);
|
|
}
|
|
|
|
return *aOffset == -1 ? S_FALSE : S_OK;
|
|
|
|
A11Y_TRYBLOCK_END
|
|
}
|
|
|
|
STDMETHODIMP
|
|
ia2AccessibleText::get_selection(long aSelectionIndex, long* aStartOffset,
|
|
long* aEndOffset)
|
|
{
|
|
A11Y_TRYBLOCK_BEGIN
|
|
|
|
if (!aStartOffset || !aEndOffset)
|
|
return E_INVALIDARG;
|
|
*aStartOffset = *aEndOffset = 0;
|
|
|
|
int32_t startOffset = 0, endOffset = 0;
|
|
if (ProxyAccessible* proxy = HyperTextProxyFor(this)) {
|
|
nsString unused;
|
|
if (!proxy->SelectionBoundsAt(aSelectionIndex, unused, &startOffset,
|
|
&endOffset))
|
|
return E_INVALIDARG;
|
|
} else {
|
|
HyperTextAccessible* textAcc = static_cast<HyperTextAccessibleWrap*>(this);
|
|
if (textAcc->IsDefunct())
|
|
return CO_E_OBJNOTCONNECTED;
|
|
|
|
if (!textAcc->SelectionBoundsAt(aSelectionIndex, &startOffset, &endOffset))
|
|
return E_INVALIDARG;
|
|
}
|
|
|
|
*aStartOffset = startOffset;
|
|
*aEndOffset = endOffset;
|
|
return S_OK;
|
|
|
|
A11Y_TRYBLOCK_END
|
|
}
|
|
|
|
STDMETHODIMP
|
|
ia2AccessibleText::get_text(long aStartOffset, long aEndOffset, BSTR* aText)
|
|
{
|
|
A11Y_TRYBLOCK_BEGIN
|
|
|
|
if (!aText)
|
|
return E_INVALIDARG;
|
|
|
|
*aText = nullptr;
|
|
|
|
nsAutoString text;
|
|
if (ProxyAccessible* proxy = HyperTextProxyFor(this)) {
|
|
if (!proxy->TextSubstring(aStartOffset, aEndOffset, text)) {
|
|
return E_INVALIDARG;
|
|
}
|
|
} else {
|
|
HyperTextAccessible* textAcc = static_cast<HyperTextAccessibleWrap*>(this);
|
|
if (textAcc->IsDefunct())
|
|
return CO_E_OBJNOTCONNECTED;
|
|
|
|
if (!textAcc->IsValidRange(aStartOffset, aEndOffset))
|
|
return E_INVALIDARG;
|
|
|
|
textAcc->TextSubstring(aStartOffset, aEndOffset, text);
|
|
}
|
|
|
|
if (text.IsEmpty())
|
|
return S_FALSE;
|
|
|
|
*aText = ::SysAllocStringLen(text.get(), text.Length());
|
|
return *aText ? S_OK : E_OUTOFMEMORY;
|
|
|
|
A11Y_TRYBLOCK_END
|
|
}
|
|
|
|
STDMETHODIMP
|
|
ia2AccessibleText::get_textBeforeOffset(long aOffset,
|
|
enum IA2TextBoundaryType aBoundaryType,
|
|
long* aStartOffset, long* aEndOffset,
|
|
BSTR* aText)
|
|
{
|
|
A11Y_TRYBLOCK_BEGIN
|
|
|
|
if (!aStartOffset || !aEndOffset || !aText)
|
|
return E_INVALIDARG;
|
|
|
|
*aStartOffset = *aEndOffset = 0;
|
|
*aText = nullptr;
|
|
|
|
HyperTextAccessible* textAcc = static_cast<HyperTextAccessibleWrap*>(this);
|
|
if (textAcc->IsDefunct())
|
|
return CO_E_OBJNOTCONNECTED;
|
|
|
|
if (!textAcc->IsValidOffset(aOffset))
|
|
return E_INVALIDARG;
|
|
|
|
nsAutoString text;
|
|
int32_t startOffset = 0, endOffset = 0;
|
|
|
|
if (aBoundaryType == IA2_TEXT_BOUNDARY_ALL) {
|
|
startOffset = 0;
|
|
endOffset = textAcc->CharacterCount();
|
|
textAcc->TextSubstring(startOffset, endOffset, text);
|
|
} else {
|
|
AccessibleTextBoundary boundaryType = GetGeckoTextBoundary(aBoundaryType);
|
|
if (boundaryType == -1)
|
|
return S_FALSE;
|
|
|
|
textAcc->TextBeforeOffset(aOffset, boundaryType, &startOffset, &endOffset, text);
|
|
}
|
|
|
|
*aStartOffset = startOffset;
|
|
*aEndOffset = endOffset;
|
|
|
|
if (text.IsEmpty())
|
|
return S_FALSE;
|
|
|
|
*aText = ::SysAllocStringLen(text.get(), text.Length());
|
|
return *aText ? S_OK : E_OUTOFMEMORY;
|
|
|
|
A11Y_TRYBLOCK_END
|
|
}
|
|
|
|
STDMETHODIMP
|
|
ia2AccessibleText::get_textAfterOffset(long aOffset,
|
|
enum IA2TextBoundaryType aBoundaryType,
|
|
long* aStartOffset, long* aEndOffset,
|
|
BSTR* aText)
|
|
{
|
|
A11Y_TRYBLOCK_BEGIN
|
|
|
|
if (!aStartOffset || !aEndOffset || !aText)
|
|
return E_INVALIDARG;
|
|
|
|
*aStartOffset = 0;
|
|
*aEndOffset = 0;
|
|
*aText = nullptr;
|
|
|
|
HyperTextAccessible* textAcc = static_cast<HyperTextAccessibleWrap*>(this);
|
|
if (textAcc->IsDefunct())
|
|
return CO_E_OBJNOTCONNECTED;
|
|
|
|
if (!textAcc->IsValidOffset(aOffset))
|
|
return E_INVALIDARG;
|
|
|
|
nsAutoString text;
|
|
int32_t startOffset = 0, endOffset = 0;
|
|
|
|
if (aBoundaryType == IA2_TEXT_BOUNDARY_ALL) {
|
|
startOffset = 0;
|
|
endOffset = textAcc->CharacterCount();
|
|
textAcc->TextSubstring(startOffset, endOffset, text);
|
|
} else {
|
|
AccessibleTextBoundary boundaryType = GetGeckoTextBoundary(aBoundaryType);
|
|
if (boundaryType == -1)
|
|
return S_FALSE;
|
|
textAcc->TextAfterOffset(aOffset, boundaryType, &startOffset, &endOffset, text);
|
|
}
|
|
|
|
*aStartOffset = startOffset;
|
|
*aEndOffset = endOffset;
|
|
|
|
if (text.IsEmpty())
|
|
return S_FALSE;
|
|
|
|
*aText = ::SysAllocStringLen(text.get(), text.Length());
|
|
return *aText ? S_OK : E_OUTOFMEMORY;
|
|
|
|
A11Y_TRYBLOCK_END
|
|
}
|
|
|
|
STDMETHODIMP
|
|
ia2AccessibleText::get_textAtOffset(long aOffset,
|
|
enum IA2TextBoundaryType aBoundaryType,
|
|
long* aStartOffset, long* aEndOffset,
|
|
BSTR* aText)
|
|
{
|
|
A11Y_TRYBLOCK_BEGIN
|
|
|
|
if (!aStartOffset || !aEndOffset || !aText)
|
|
return E_INVALIDARG;
|
|
|
|
*aStartOffset = *aEndOffset = 0;
|
|
*aText = nullptr;
|
|
|
|
HyperTextAccessible* textAcc = static_cast<HyperTextAccessibleWrap*>(this);
|
|
if (textAcc->IsDefunct())
|
|
return CO_E_OBJNOTCONNECTED;
|
|
|
|
if (!textAcc->IsValidOffset(aOffset))
|
|
return E_INVALIDARG;
|
|
|
|
nsAutoString text;
|
|
int32_t startOffset = 0, endOffset = 0;
|
|
if (aBoundaryType == IA2_TEXT_BOUNDARY_ALL) {
|
|
startOffset = 0;
|
|
endOffset = textAcc->CharacterCount();
|
|
textAcc->TextSubstring(startOffset, endOffset, text);
|
|
} else {
|
|
AccessibleTextBoundary boundaryType = GetGeckoTextBoundary(aBoundaryType);
|
|
if (boundaryType == -1)
|
|
return S_FALSE;
|
|
textAcc->TextAtOffset(aOffset, boundaryType, &startOffset, &endOffset, text);
|
|
}
|
|
|
|
*aStartOffset = startOffset;
|
|
*aEndOffset = endOffset;
|
|
|
|
if (text.IsEmpty())
|
|
return S_FALSE;
|
|
|
|
*aText = ::SysAllocStringLen(text.get(), text.Length());
|
|
return *aText ? S_OK : E_OUTOFMEMORY;
|
|
|
|
A11Y_TRYBLOCK_END
|
|
}
|
|
|
|
STDMETHODIMP
|
|
ia2AccessibleText::removeSelection(long aSelectionIndex)
|
|
{
|
|
A11Y_TRYBLOCK_BEGIN
|
|
|
|
if (ProxyAccessible* proxy = HyperTextProxyFor(this)) {
|
|
return proxy->RemoveFromSelection(aSelectionIndex) ? S_OK : E_INVALIDARG;
|
|
}
|
|
|
|
HyperTextAccessible* textAcc = static_cast<HyperTextAccessibleWrap*>(this);
|
|
if (textAcc->IsDefunct())
|
|
return CO_E_OBJNOTCONNECTED;
|
|
|
|
return textAcc->RemoveFromSelection(aSelectionIndex) ?
|
|
S_OK : E_INVALIDARG;
|
|
|
|
A11Y_TRYBLOCK_END
|
|
}
|
|
|
|
STDMETHODIMP
|
|
ia2AccessibleText::setCaretOffset(long aOffset)
|
|
{
|
|
A11Y_TRYBLOCK_BEGIN
|
|
|
|
if (ProxyAccessible* proxy = HyperTextProxyFor(this)) {
|
|
proxy->SetCaretOffset(aOffset);
|
|
return S_OK;
|
|
}
|
|
|
|
HyperTextAccessible* textAcc = static_cast<HyperTextAccessibleWrap*>(this);
|
|
if (textAcc->IsDefunct())
|
|
return CO_E_OBJNOTCONNECTED;
|
|
|
|
if (!textAcc->IsValidOffset(aOffset))
|
|
return E_INVALIDARG;
|
|
|
|
textAcc->SetCaretOffset(aOffset);
|
|
return S_OK;
|
|
|
|
A11Y_TRYBLOCK_END
|
|
}
|
|
|
|
STDMETHODIMP
|
|
ia2AccessibleText::setSelection(long aSelectionIndex, long aStartOffset,
|
|
long aEndOffset)
|
|
{
|
|
A11Y_TRYBLOCK_BEGIN
|
|
|
|
if (ProxyAccessible* proxy = HyperTextProxyFor(this)) {
|
|
return proxy->SetSelectionBoundsAt(aSelectionIndex, aStartOffset,
|
|
aEndOffset) ? S_OK : E_INVALIDARG;
|
|
}
|
|
|
|
HyperTextAccessible* textAcc = static_cast<HyperTextAccessibleWrap*>(this);
|
|
if (textAcc->IsDefunct())
|
|
return CO_E_OBJNOTCONNECTED;
|
|
|
|
return textAcc->SetSelectionBoundsAt(aSelectionIndex, aStartOffset, aEndOffset) ?
|
|
S_OK : E_INVALIDARG;
|
|
|
|
A11Y_TRYBLOCK_END
|
|
}
|
|
|
|
STDMETHODIMP
|
|
ia2AccessibleText::get_nCharacters(long* aNCharacters)
|
|
{
|
|
A11Y_TRYBLOCK_BEGIN
|
|
|
|
if (!aNCharacters)
|
|
return E_INVALIDARG;
|
|
*aNCharacters = 0;
|
|
|
|
if (ProxyAccessible* proxy = HyperTextProxyFor(this)) {
|
|
*aNCharacters = proxy->CharacterCount();
|
|
return S_OK;
|
|
}
|
|
|
|
HyperTextAccessible* textAcc = static_cast<HyperTextAccessibleWrap*>(this);
|
|
if (textAcc->IsDefunct())
|
|
return CO_E_OBJNOTCONNECTED;
|
|
|
|
*aNCharacters = textAcc->CharacterCount();
|
|
return S_OK;
|
|
|
|
A11Y_TRYBLOCK_END
|
|
}
|
|
|
|
STDMETHODIMP
|
|
ia2AccessibleText::scrollSubstringTo(long aStartIndex, long aEndIndex,
|
|
enum IA2ScrollType aScrollType)
|
|
{
|
|
A11Y_TRYBLOCK_BEGIN
|
|
|
|
if (ProxyAccessible* proxy = HyperTextProxyFor(this)) {
|
|
proxy->ScrollSubstringTo(aStartIndex, aEndIndex, aScrollType);
|
|
return S_OK;
|
|
}
|
|
|
|
HyperTextAccessible* textAcc = static_cast<HyperTextAccessibleWrap*>(this);
|
|
if (textAcc->IsDefunct())
|
|
return CO_E_OBJNOTCONNECTED;
|
|
|
|
if (!textAcc->IsValidRange(aStartIndex, aEndIndex))
|
|
return E_INVALIDARG;
|
|
|
|
textAcc->ScrollSubstringTo(aStartIndex, aEndIndex, aScrollType);
|
|
return S_OK;
|
|
|
|
A11Y_TRYBLOCK_END
|
|
}
|
|
|
|
STDMETHODIMP
|
|
ia2AccessibleText::scrollSubstringToPoint(long aStartIndex, long aEndIndex,
|
|
enum IA2CoordinateType aCoordType,
|
|
long aX, long aY)
|
|
{
|
|
A11Y_TRYBLOCK_BEGIN
|
|
|
|
uint32_t geckoCoordType = (aCoordType == IA2_COORDTYPE_SCREEN_RELATIVE) ?
|
|
nsIAccessibleCoordinateType::COORDTYPE_SCREEN_RELATIVE :
|
|
nsIAccessibleCoordinateType::COORDTYPE_PARENT_RELATIVE;
|
|
|
|
if (ProxyAccessible* proxy = HyperTextProxyFor(this)) {
|
|
proxy->ScrollSubstringToPoint(aStartIndex, aEndIndex, geckoCoordType, aX,
|
|
aY);
|
|
return S_OK;
|
|
}
|
|
|
|
HyperTextAccessible* textAcc = static_cast<HyperTextAccessibleWrap*>(this);
|
|
if (textAcc->IsDefunct())
|
|
return CO_E_OBJNOTCONNECTED;
|
|
|
|
if (!textAcc->IsValidRange(aStartIndex, aEndIndex))
|
|
return E_INVALIDARG;
|
|
|
|
textAcc->ScrollSubstringToPoint(aStartIndex, aEndIndex,
|
|
geckoCoordType, aX, aY);
|
|
return S_OK;
|
|
|
|
A11Y_TRYBLOCK_END
|
|
}
|
|
|
|
STDMETHODIMP
|
|
ia2AccessibleText::get_newText(IA2TextSegment *aNewText)
|
|
{
|
|
A11Y_TRYBLOCK_BEGIN
|
|
|
|
return GetModifiedText(true, aNewText);
|
|
|
|
A11Y_TRYBLOCK_END
|
|
}
|
|
|
|
STDMETHODIMP
|
|
ia2AccessibleText::get_oldText(IA2TextSegment *aOldText)
|
|
{
|
|
A11Y_TRYBLOCK_BEGIN
|
|
|
|
return GetModifiedText(false, aOldText);
|
|
|
|
A11Y_TRYBLOCK_END
|
|
}
|
|
|
|
// ia2AccessibleText
|
|
|
|
HRESULT
|
|
ia2AccessibleText::GetModifiedText(bool aGetInsertedText,
|
|
IA2TextSegment *aText)
|
|
{
|
|
if (!aText)
|
|
return E_INVALIDARG;
|
|
|
|
if (!sLastTextChangeAcc)
|
|
return S_OK;
|
|
|
|
if (aGetInsertedText != sLastTextChangeWasInsert)
|
|
return S_OK;
|
|
|
|
if (sLastTextChangeAcc != this)
|
|
return S_OK;
|
|
|
|
aText->start = sLastTextChangeStart;
|
|
aText->end = sLastTextChangeEnd;
|
|
|
|
if (sLastTextChangeString->IsEmpty())
|
|
return S_FALSE;
|
|
|
|
aText->text = ::SysAllocStringLen(sLastTextChangeString->get(), sLastTextChangeString->Length());
|
|
return aText->text ? S_OK : E_OUTOFMEMORY;
|
|
}
|
|
|
|
AccessibleTextBoundary
|
|
ia2AccessibleText::GetGeckoTextBoundary(enum IA2TextBoundaryType aBoundaryType)
|
|
{
|
|
switch (aBoundaryType) {
|
|
case IA2_TEXT_BOUNDARY_CHAR:
|
|
return nsIAccessibleText::BOUNDARY_CHAR;
|
|
case IA2_TEXT_BOUNDARY_WORD:
|
|
return nsIAccessibleText::BOUNDARY_WORD_START;
|
|
case IA2_TEXT_BOUNDARY_LINE:
|
|
return nsIAccessibleText::BOUNDARY_LINE_START;
|
|
//case IA2_TEXT_BOUNDARY_SENTENCE:
|
|
//case IA2_TEXT_BOUNDARY_PARAGRAPH:
|
|
// XXX: not implemented
|
|
default:
|
|
return -1;
|
|
}
|
|
}
|
|
|
|
void
|
|
ia2AccessibleText::InitTextChangeData()
|
|
{
|
|
ClearOnShutdown(&sLastTextChangeAcc);
|
|
ClearOnShutdown(&sLastTextChangeString);
|
|
}
|
|
|
|
void
|
|
ia2AccessibleText::UpdateTextChangeData(HyperTextAccessibleWrap* aAcc,
|
|
bool aInsert, const nsString& aStr,
|
|
int32_t aStart, uint32_t aLen)
|
|
{
|
|
if (!sLastTextChangeString)
|
|
sLastTextChangeString = new nsString();
|
|
|
|
sLastTextChangeAcc = aAcc;
|
|
sLastTextChangeStart = aStart;
|
|
sLastTextChangeEnd = aStart + aLen;
|
|
sLastTextChangeWasInsert = aInsert;
|
|
*sLastTextChangeString = aStr;
|
|
}
|