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)
494 lines
12 KiB
C++
494 lines
12 KiB
C++
/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
|
|
/* vim: set ts=2 et sw=2 tw=80: */
|
|
/* 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 "xpcAccessibleTable.h"
|
|
|
|
#include "Accessible.h"
|
|
#include "TableAccessible.h"
|
|
#include "xpcAccessibleDocument.h"
|
|
|
|
#include "nsIMutableArray.h"
|
|
#include "nsComponentManagerUtils.h"
|
|
|
|
using namespace mozilla::a11y;
|
|
|
|
static const uint32_t XPC_TABLE_DEFAULT_SIZE = 40;
|
|
|
|
////////////////////////////////////////////////////////////////////////////////
|
|
// nsISupports
|
|
|
|
NS_IMPL_ISUPPORTS_INHERITED(xpcAccessibleTable,
|
|
xpcAccessibleGeneric,
|
|
nsIAccessibleTable)
|
|
|
|
////////////////////////////////////////////////////////////////////////////////
|
|
// nsIAccessibleTable
|
|
|
|
NS_IMETHODIMP
|
|
xpcAccessibleTable::GetCaption(nsIAccessible** aCaption)
|
|
{
|
|
NS_ENSURE_ARG_POINTER(aCaption);
|
|
*aCaption = nullptr;
|
|
if (!Intl())
|
|
return NS_ERROR_FAILURE;
|
|
|
|
NS_IF_ADDREF(*aCaption = ToXPC(Intl()->Caption()));
|
|
return NS_OK;
|
|
}
|
|
|
|
NS_IMETHODIMP
|
|
xpcAccessibleTable::GetColumnCount(int32_t* aColumnCount)
|
|
{
|
|
NS_ENSURE_ARG_POINTER(aColumnCount);
|
|
*aColumnCount = 0;
|
|
|
|
if (!Intl())
|
|
return NS_ERROR_FAILURE;
|
|
|
|
*aColumnCount = Intl()->ColCount();
|
|
return NS_OK;
|
|
}
|
|
|
|
NS_IMETHODIMP
|
|
xpcAccessibleTable::GetRowCount(int32_t* aRowCount)
|
|
{
|
|
NS_ENSURE_ARG_POINTER(aRowCount);
|
|
*aRowCount = 0;
|
|
|
|
if (!Intl())
|
|
return NS_ERROR_FAILURE;
|
|
|
|
*aRowCount = Intl()->RowCount();
|
|
return NS_OK;
|
|
}
|
|
|
|
NS_IMETHODIMP
|
|
xpcAccessibleTable::GetCellAt(int32_t aRowIdx, int32_t aColIdx,
|
|
nsIAccessible** aCell)
|
|
{
|
|
NS_ENSURE_ARG_POINTER(aCell);
|
|
*aCell = nullptr;
|
|
|
|
if (!Intl())
|
|
return NS_ERROR_FAILURE;
|
|
|
|
if (aRowIdx < 0 || static_cast<uint32_t>(aRowIdx) >= Intl()->RowCount() ||
|
|
aColIdx < 0 || static_cast<uint32_t>(aColIdx) >= Intl()->ColCount())
|
|
return NS_ERROR_INVALID_ARG;
|
|
|
|
NS_IF_ADDREF(*aCell = ToXPC(Intl()->CellAt(aRowIdx, aColIdx)));
|
|
return NS_OK;
|
|
}
|
|
|
|
NS_IMETHODIMP
|
|
xpcAccessibleTable::GetCellIndexAt(int32_t aRowIdx, int32_t aColIdx,
|
|
int32_t* aCellIdx)
|
|
{
|
|
NS_ENSURE_ARG_POINTER(aCellIdx);
|
|
*aCellIdx = -1;
|
|
|
|
if (!Intl())
|
|
return NS_ERROR_FAILURE;
|
|
|
|
if (aRowIdx < 0 || static_cast<uint32_t>(aRowIdx) >= Intl()->RowCount() ||
|
|
aColIdx < 0 || static_cast<uint32_t>(aColIdx) >= Intl()->ColCount())
|
|
return NS_ERROR_INVALID_ARG;
|
|
|
|
*aCellIdx = Intl()->CellIndexAt(aRowIdx, aColIdx);
|
|
return NS_OK;
|
|
}
|
|
|
|
NS_IMETHODIMP
|
|
xpcAccessibleTable::GetColumnExtentAt(int32_t aRowIdx, int32_t aColIdx,
|
|
int32_t* aColumnExtent)
|
|
{
|
|
NS_ENSURE_ARG_POINTER(aColumnExtent);
|
|
*aColumnExtent = -1;
|
|
|
|
if (!Intl())
|
|
return NS_ERROR_FAILURE;
|
|
|
|
if (aRowIdx < 0 || static_cast<uint32_t>(aRowIdx) >= Intl()->RowCount() ||
|
|
aColIdx < 0 || static_cast<uint32_t>(aColIdx) >= Intl()->ColCount())
|
|
return NS_ERROR_INVALID_ARG;
|
|
|
|
*aColumnExtent = Intl()->ColExtentAt(aRowIdx, aColIdx);
|
|
return NS_OK;
|
|
}
|
|
|
|
NS_IMETHODIMP
|
|
xpcAccessibleTable::GetRowExtentAt(int32_t aRowIdx, int32_t aColIdx,
|
|
int32_t* aRowExtent)
|
|
{
|
|
NS_ENSURE_ARG_POINTER(aRowExtent);
|
|
*aRowExtent = -1;
|
|
|
|
if (!Intl())
|
|
return NS_ERROR_FAILURE;
|
|
|
|
if (aRowIdx < 0 || static_cast<uint32_t>(aRowIdx) >= Intl()->RowCount() ||
|
|
aColIdx < 0 || static_cast<uint32_t>(aColIdx) >= Intl()->ColCount())
|
|
return NS_ERROR_INVALID_ARG;
|
|
|
|
*aRowExtent = Intl()->RowExtentAt(aRowIdx, aColIdx);
|
|
return NS_OK;
|
|
}
|
|
|
|
NS_IMETHODIMP
|
|
xpcAccessibleTable::GetColumnDescription(int32_t aColIdx,
|
|
nsAString& aDescription)
|
|
{
|
|
if (!Intl())
|
|
return NS_ERROR_FAILURE;
|
|
|
|
if (aColIdx < 0 || static_cast<uint32_t>(aColIdx) >= Intl()->ColCount())
|
|
return NS_ERROR_INVALID_ARG;
|
|
|
|
nsAutoString description;
|
|
Intl()->ColDescription(aColIdx, description);
|
|
aDescription.Assign(description);
|
|
|
|
return NS_OK;
|
|
}
|
|
|
|
NS_IMETHODIMP
|
|
xpcAccessibleTable::GetRowDescription(int32_t aRowIdx, nsAString& aDescription)
|
|
{
|
|
if (!Intl())
|
|
return NS_ERROR_FAILURE;
|
|
|
|
if (aRowIdx < 0 || static_cast<uint32_t>(aRowIdx) >= Intl()->ColCount())
|
|
return NS_ERROR_INVALID_ARG;
|
|
|
|
nsAutoString description;
|
|
Intl()->RowDescription(aRowIdx, description);
|
|
aDescription.Assign(description);
|
|
|
|
return NS_OK;
|
|
}
|
|
|
|
NS_IMETHODIMP
|
|
xpcAccessibleTable::IsColumnSelected(int32_t aColIdx, bool* aIsSelected)
|
|
{
|
|
NS_ENSURE_ARG_POINTER(aIsSelected);
|
|
*aIsSelected = false;
|
|
|
|
if (!Intl())
|
|
return NS_ERROR_FAILURE;
|
|
|
|
if (aColIdx < 0 || static_cast<uint32_t>(aColIdx) >= Intl()->ColCount())
|
|
return NS_ERROR_INVALID_ARG;
|
|
|
|
*aIsSelected = Intl()->IsColSelected(aColIdx);
|
|
return NS_OK;
|
|
}
|
|
|
|
NS_IMETHODIMP
|
|
xpcAccessibleTable::IsRowSelected(int32_t aRowIdx, bool* aIsSelected)
|
|
{
|
|
NS_ENSURE_ARG_POINTER(aIsSelected);
|
|
*aIsSelected = false;
|
|
|
|
if (!Intl())
|
|
return NS_ERROR_FAILURE;
|
|
|
|
if (aRowIdx < 0 || static_cast<uint32_t>(aRowIdx) >= Intl()->RowCount())
|
|
return NS_ERROR_INVALID_ARG;
|
|
|
|
*aIsSelected = Intl()->IsRowSelected(aRowIdx);
|
|
return NS_OK;
|
|
}
|
|
|
|
NS_IMETHODIMP
|
|
xpcAccessibleTable::IsCellSelected(int32_t aRowIdx, int32_t aColIdx,
|
|
bool* aIsSelected)
|
|
{
|
|
NS_ENSURE_ARG_POINTER(aIsSelected);
|
|
*aIsSelected = false;
|
|
|
|
if (!Intl())
|
|
return NS_ERROR_FAILURE;
|
|
|
|
if (aRowIdx < 0 || static_cast<uint32_t>(aRowIdx) >= Intl()->RowCount() ||
|
|
aColIdx < 0 || static_cast<uint32_t>(aColIdx) >= Intl()->ColCount())
|
|
return NS_ERROR_INVALID_ARG;
|
|
|
|
*aIsSelected = Intl()->IsCellSelected(aRowIdx, aColIdx);
|
|
return NS_OK;
|
|
}
|
|
|
|
NS_IMETHODIMP
|
|
xpcAccessibleTable::GetSelectedCellCount(uint32_t* aSelectedCellCount)
|
|
{
|
|
NS_ENSURE_ARG_POINTER(aSelectedCellCount);
|
|
*aSelectedCellCount = 0;
|
|
|
|
if (!Intl())
|
|
return NS_ERROR_FAILURE;
|
|
|
|
*aSelectedCellCount = Intl()->SelectedCellCount();
|
|
return NS_OK;
|
|
}
|
|
|
|
NS_IMETHODIMP
|
|
xpcAccessibleTable::GetSelectedColumnCount(uint32_t* aSelectedColumnCount)
|
|
{
|
|
NS_ENSURE_ARG_POINTER(aSelectedColumnCount);
|
|
*aSelectedColumnCount = 0;
|
|
|
|
if (!Intl())
|
|
return NS_ERROR_FAILURE;
|
|
|
|
*aSelectedColumnCount = Intl()->SelectedColCount();
|
|
return NS_OK;
|
|
}
|
|
|
|
NS_IMETHODIMP
|
|
xpcAccessibleTable::GetSelectedRowCount(uint32_t* aSelectedRowCount)
|
|
{
|
|
NS_ENSURE_ARG_POINTER(aSelectedRowCount);
|
|
*aSelectedRowCount = 0;
|
|
|
|
if (!Intl())
|
|
return NS_ERROR_FAILURE;
|
|
|
|
*aSelectedRowCount = Intl()->SelectedRowCount();
|
|
return NS_OK;
|
|
}
|
|
|
|
NS_IMETHODIMP
|
|
xpcAccessibleTable::GetSelectedCells(nsIArray** aSelectedCells)
|
|
{
|
|
NS_ENSURE_ARG_POINTER(aSelectedCells);
|
|
*aSelectedCells = nullptr;
|
|
|
|
if (!Intl())
|
|
return NS_ERROR_FAILURE;
|
|
|
|
nsresult rv = NS_OK;
|
|
nsCOMPtr<nsIMutableArray> selCells =
|
|
do_CreateInstance(NS_ARRAY_CONTRACTID, &rv);
|
|
NS_ENSURE_SUCCESS(rv, rv);
|
|
|
|
AutoTArray<Accessible*, XPC_TABLE_DEFAULT_SIZE> cellsArray;
|
|
Intl()->SelectedCells(&cellsArray);
|
|
|
|
uint32_t totalCount = cellsArray.Length();
|
|
for (uint32_t idx = 0; idx < totalCount; idx++) {
|
|
Accessible* cell = cellsArray.ElementAt(idx);
|
|
selCells->AppendElement(static_cast<nsIAccessible*>(ToXPC(cell)), false);
|
|
}
|
|
|
|
NS_ADDREF(*aSelectedCells = selCells);
|
|
return NS_OK;
|
|
}
|
|
|
|
NS_IMETHODIMP
|
|
xpcAccessibleTable::GetSelectedCellIndices(uint32_t* aCellsArraySize,
|
|
int32_t** aCellsArray)
|
|
{
|
|
NS_ENSURE_ARG_POINTER(aCellsArraySize);
|
|
*aCellsArraySize = 0;
|
|
|
|
NS_ENSURE_ARG_POINTER(aCellsArray);
|
|
*aCellsArray = 0;
|
|
|
|
if (!Intl())
|
|
return NS_ERROR_FAILURE;
|
|
|
|
AutoTArray<uint32_t, XPC_TABLE_DEFAULT_SIZE> cellsArray;
|
|
Intl()->SelectedCellIndices(&cellsArray);
|
|
|
|
*aCellsArraySize = cellsArray.Length();
|
|
*aCellsArray = static_cast<int32_t*>
|
|
(moz_xmalloc(*aCellsArraySize * sizeof(int32_t)));
|
|
memcpy(*aCellsArray, cellsArray.Elements(),
|
|
*aCellsArraySize * sizeof(int32_t));
|
|
|
|
return NS_OK;
|
|
}
|
|
|
|
NS_IMETHODIMP
|
|
xpcAccessibleTable::GetSelectedColumnIndices(uint32_t* aColsArraySize,
|
|
int32_t** aColsArray)
|
|
{
|
|
NS_ENSURE_ARG_POINTER(aColsArraySize);
|
|
*aColsArraySize = 0;
|
|
|
|
NS_ENSURE_ARG_POINTER(aColsArray);
|
|
*aColsArray = 0;
|
|
|
|
if (!Intl())
|
|
return NS_ERROR_FAILURE;
|
|
|
|
AutoTArray<uint32_t, XPC_TABLE_DEFAULT_SIZE> colsArray;
|
|
Intl()->SelectedColIndices(&colsArray);
|
|
|
|
*aColsArraySize = colsArray.Length();
|
|
*aColsArray = static_cast<int32_t*>
|
|
(moz_xmalloc(*aColsArraySize * sizeof(int32_t)));
|
|
memcpy(*aColsArray, colsArray.Elements(),
|
|
*aColsArraySize * sizeof(int32_t));
|
|
|
|
return NS_OK;
|
|
}
|
|
|
|
NS_IMETHODIMP
|
|
xpcAccessibleTable::GetSelectedRowIndices(uint32_t* aRowsArraySize,
|
|
int32_t** aRowsArray)
|
|
{
|
|
NS_ENSURE_ARG_POINTER(aRowsArraySize);
|
|
*aRowsArraySize = 0;
|
|
|
|
NS_ENSURE_ARG_POINTER(aRowsArray);
|
|
*aRowsArray = 0;
|
|
|
|
if (!Intl())
|
|
return NS_ERROR_FAILURE;
|
|
|
|
AutoTArray<uint32_t, XPC_TABLE_DEFAULT_SIZE> rowsArray;
|
|
Intl()->SelectedRowIndices(&rowsArray);
|
|
|
|
*aRowsArraySize = rowsArray.Length();
|
|
*aRowsArray = static_cast<int32_t*>
|
|
(moz_xmalloc(*aRowsArraySize * sizeof(int32_t)));
|
|
memcpy(*aRowsArray, rowsArray.Elements(),
|
|
*aRowsArraySize * sizeof(int32_t));
|
|
|
|
return NS_OK;
|
|
}
|
|
|
|
NS_IMETHODIMP
|
|
xpcAccessibleTable::GetColumnIndexAt(int32_t aCellIdx, int32_t* aColIdx)
|
|
{
|
|
NS_ENSURE_ARG_POINTER(aColIdx);
|
|
*aColIdx = -1;
|
|
|
|
if (!Intl())
|
|
return NS_ERROR_FAILURE;
|
|
|
|
if (aCellIdx < 0 ||
|
|
static_cast<uint32_t>(aCellIdx) >= Intl()->RowCount() * Intl()->ColCount())
|
|
return NS_ERROR_INVALID_ARG;
|
|
|
|
*aColIdx = Intl()->ColIndexAt(aCellIdx);
|
|
return NS_OK;
|
|
}
|
|
|
|
NS_IMETHODIMP
|
|
xpcAccessibleTable::GetRowIndexAt(int32_t aCellIdx, int32_t* aRowIdx)
|
|
{
|
|
NS_ENSURE_ARG_POINTER(aRowIdx);
|
|
*aRowIdx = -1;
|
|
|
|
if (!Intl())
|
|
return NS_ERROR_FAILURE;
|
|
|
|
if (aCellIdx < 0 ||
|
|
static_cast<uint32_t>(aCellIdx) >= Intl()->RowCount() * Intl()->ColCount())
|
|
return NS_ERROR_INVALID_ARG;
|
|
|
|
*aRowIdx = Intl()->RowIndexAt(aCellIdx);
|
|
return NS_OK;
|
|
}
|
|
|
|
NS_IMETHODIMP
|
|
xpcAccessibleTable::GetRowAndColumnIndicesAt(int32_t aCellIdx, int32_t* aRowIdx,
|
|
int32_t* aColIdx)
|
|
{
|
|
NS_ENSURE_ARG_POINTER(aRowIdx);
|
|
*aRowIdx = -1;
|
|
NS_ENSURE_ARG_POINTER(aColIdx);
|
|
*aColIdx = -1;
|
|
|
|
if (!Intl())
|
|
return NS_ERROR_FAILURE;
|
|
|
|
if (aCellIdx < 0 ||
|
|
static_cast<uint32_t>(aCellIdx) >= Intl()->RowCount() * Intl()->ColCount())
|
|
return NS_ERROR_INVALID_ARG;
|
|
|
|
Intl()->RowAndColIndicesAt(aCellIdx, aRowIdx, aColIdx);
|
|
return NS_OK;
|
|
}
|
|
|
|
NS_IMETHODIMP
|
|
xpcAccessibleTable::GetSummary(nsAString& aSummary)
|
|
{
|
|
if (!Intl())
|
|
return NS_ERROR_FAILURE;
|
|
|
|
nsAutoString summary;
|
|
Intl()->Summary(summary);
|
|
aSummary.Assign(summary);
|
|
|
|
return NS_OK;
|
|
}
|
|
|
|
NS_IMETHODIMP
|
|
xpcAccessibleTable::IsProbablyForLayout(bool* aResult)
|
|
{
|
|
NS_ENSURE_ARG_POINTER(aResult);
|
|
*aResult = false;
|
|
if (!Intl())
|
|
return NS_ERROR_FAILURE;
|
|
|
|
*aResult = Intl()->IsProbablyLayoutTable();
|
|
return NS_OK;
|
|
}
|
|
|
|
NS_IMETHODIMP
|
|
xpcAccessibleTable::SelectColumn(int32_t aColIdx)
|
|
{
|
|
if (!Intl())
|
|
return NS_ERROR_FAILURE;
|
|
|
|
if (aColIdx < 0 || static_cast<uint32_t>(aColIdx) >= Intl()->ColCount())
|
|
return NS_ERROR_INVALID_ARG;
|
|
|
|
Intl()->SelectCol(aColIdx);
|
|
return NS_OK;
|
|
}
|
|
|
|
NS_IMETHODIMP
|
|
xpcAccessibleTable::SelectRow(int32_t aRowIdx)
|
|
{
|
|
if (!Intl())
|
|
return NS_ERROR_FAILURE;
|
|
|
|
if (aRowIdx < 0 || static_cast<uint32_t>(aRowIdx) >= Intl()->RowCount())
|
|
return NS_ERROR_INVALID_ARG;
|
|
|
|
Intl()->SelectRow(aRowIdx);
|
|
return NS_OK;
|
|
}
|
|
|
|
NS_IMETHODIMP
|
|
xpcAccessibleTable::UnselectColumn(int32_t aColIdx)
|
|
{
|
|
if (!Intl())
|
|
return NS_ERROR_FAILURE;
|
|
|
|
if (aColIdx < 0 || static_cast<uint32_t>(aColIdx) >= Intl()->ColCount())
|
|
return NS_ERROR_INVALID_ARG;
|
|
|
|
Intl()->UnselectCol(aColIdx);
|
|
return NS_OK;
|
|
}
|
|
|
|
NS_IMETHODIMP
|
|
xpcAccessibleTable::UnselectRow(int32_t aRowIdx)
|
|
{
|
|
if (!Intl())
|
|
return NS_ERROR_FAILURE;
|
|
|
|
if (aRowIdx < 0 || static_cast<uint32_t>(aRowIdx) >= Intl()->RowCount())
|
|
return NS_ERROR_INVALID_ARG;
|
|
|
|
Intl()->UnselectRow(aRowIdx);
|
|
return NS_OK;
|
|
}
|