no bug - Correct some typos in the comments. a=typo-fix
[gecko.git] / accessible / xpcom / xpcAccessibleTable.cpp
blobb7de1cd85ca556e164a6334c2e253a2068dbaaae
1 /* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
2 /* vim: set ts=2 et sw=2 tw=80: */
3 /* This Source Code Form is subject to the terms of the Mozilla Public
4 * License, v. 2.0. If a copy of the MPL was not distributed with this file,
5 * You can obtain one at http://mozilla.org/MPL/2.0/. */
7 #include "xpcAccessibleTable.h"
9 #include "mozilla/a11y/TableAccessible.h"
11 #include "nsIMutableArray.h"
12 #include "nsComponentManagerUtils.h"
13 #include "xpcAccessibleDocument.h"
15 using namespace mozilla::a11y;
17 static const uint32_t XPC_TABLE_DEFAULT_SIZE = 40;
19 ////////////////////////////////////////////////////////////////////////////////
20 // nsISupports
22 NS_IMPL_ISUPPORTS_INHERITED(xpcAccessibleTable, xpcAccessibleHyperText,
23 nsIAccessibleTable)
25 ////////////////////////////////////////////////////////////////////////////////
26 // nsIAccessibleTable
28 NS_IMETHODIMP
29 xpcAccessibleTable::GetCaption(nsIAccessible** aCaption) {
30 NS_ENSURE_ARG_POINTER(aCaption);
31 *aCaption = nullptr;
32 if (!Intl()) return NS_ERROR_FAILURE;
34 NS_IF_ADDREF(*aCaption = ToXPC(Intl()->Caption()));
35 return NS_OK;
38 NS_IMETHODIMP
39 xpcAccessibleTable::GetColumnCount(int32_t* aColumnCount) {
40 NS_ENSURE_ARG_POINTER(aColumnCount);
41 *aColumnCount = 0;
43 if (!Intl()) return NS_ERROR_FAILURE;
45 *aColumnCount = Intl()->ColCount();
46 return NS_OK;
49 NS_IMETHODIMP
50 xpcAccessibleTable::GetRowCount(int32_t* aRowCount) {
51 NS_ENSURE_ARG_POINTER(aRowCount);
52 *aRowCount = 0;
54 if (!Intl()) return NS_ERROR_FAILURE;
56 *aRowCount = Intl()->RowCount();
57 return NS_OK;
60 NS_IMETHODIMP
61 xpcAccessibleTable::GetCellAt(int32_t aRowIdx, int32_t aColIdx,
62 nsIAccessible** aCell) {
63 NS_ENSURE_ARG_POINTER(aCell);
64 *aCell = nullptr;
66 if (!Intl()) return NS_ERROR_FAILURE;
68 if (aRowIdx < 0 || static_cast<uint32_t>(aRowIdx) >= Intl()->RowCount() ||
69 aColIdx < 0 || static_cast<uint32_t>(aColIdx) >= Intl()->ColCount()) {
70 return NS_ERROR_INVALID_ARG;
73 NS_IF_ADDREF(*aCell = ToXPC(Intl()->CellAt(aRowIdx, aColIdx)));
74 return NS_OK;
77 NS_IMETHODIMP
78 xpcAccessibleTable::GetCellIndexAt(int32_t aRowIdx, int32_t aColIdx,
79 int32_t* aCellIdx) {
80 NS_ENSURE_ARG_POINTER(aCellIdx);
81 *aCellIdx = -1;
83 if (!Intl()) return NS_ERROR_FAILURE;
85 if (aRowIdx < 0 || static_cast<uint32_t>(aRowIdx) >= Intl()->RowCount() ||
86 aColIdx < 0 || static_cast<uint32_t>(aColIdx) >= Intl()->ColCount()) {
87 return NS_ERROR_INVALID_ARG;
90 *aCellIdx = Intl()->CellIndexAt(aRowIdx, aColIdx);
91 return NS_OK;
94 NS_IMETHODIMP
95 xpcAccessibleTable::GetColumnExtentAt(int32_t aRowIdx, int32_t aColIdx,
96 int32_t* aColumnExtent) {
97 NS_ENSURE_ARG_POINTER(aColumnExtent);
98 *aColumnExtent = -1;
100 if (!Intl()) return NS_ERROR_FAILURE;
102 if (aRowIdx < 0 || static_cast<uint32_t>(aRowIdx) >= Intl()->RowCount() ||
103 aColIdx < 0 || static_cast<uint32_t>(aColIdx) >= Intl()->ColCount()) {
104 return NS_ERROR_INVALID_ARG;
107 *aColumnExtent = Intl()->ColExtentAt(aRowIdx, aColIdx);
108 return NS_OK;
111 NS_IMETHODIMP
112 xpcAccessibleTable::GetRowExtentAt(int32_t aRowIdx, int32_t aColIdx,
113 int32_t* aRowExtent) {
114 NS_ENSURE_ARG_POINTER(aRowExtent);
115 *aRowExtent = -1;
117 if (!Intl()) return NS_ERROR_FAILURE;
119 if (aRowIdx < 0 || static_cast<uint32_t>(aRowIdx) >= Intl()->RowCount() ||
120 aColIdx < 0 || static_cast<uint32_t>(aColIdx) >= Intl()->ColCount()) {
121 return NS_ERROR_INVALID_ARG;
124 *aRowExtent = Intl()->RowExtentAt(aRowIdx, aColIdx);
125 return NS_OK;
128 NS_IMETHODIMP
129 xpcAccessibleTable::GetColumnDescription(int32_t aColIdx,
130 nsAString& aDescription) {
131 if (!Intl()) return NS_ERROR_FAILURE;
133 if (aColIdx < 0 || static_cast<uint32_t>(aColIdx) >= Intl()->ColCount()) {
134 return NS_ERROR_INVALID_ARG;
137 nsAutoString description;
138 Intl()->ColDescription(aColIdx, description);
139 aDescription.Assign(description);
141 return NS_OK;
144 NS_IMETHODIMP
145 xpcAccessibleTable::GetRowDescription(int32_t aRowIdx,
146 nsAString& aDescription) {
147 if (!Intl()) return NS_ERROR_FAILURE;
149 if (aRowIdx < 0 || static_cast<uint32_t>(aRowIdx) >= Intl()->ColCount()) {
150 return NS_ERROR_INVALID_ARG;
153 nsAutoString description;
154 Intl()->RowDescription(aRowIdx, description);
155 aDescription.Assign(description);
157 return NS_OK;
160 NS_IMETHODIMP
161 xpcAccessibleTable::IsColumnSelected(int32_t aColIdx, bool* aIsSelected) {
162 NS_ENSURE_ARG_POINTER(aIsSelected);
163 *aIsSelected = false;
165 if (!Intl()) return NS_ERROR_FAILURE;
167 if (aColIdx < 0 || static_cast<uint32_t>(aColIdx) >= Intl()->ColCount()) {
168 return NS_ERROR_INVALID_ARG;
171 *aIsSelected = Intl()->IsColSelected(aColIdx);
172 return NS_OK;
175 NS_IMETHODIMP
176 xpcAccessibleTable::IsRowSelected(int32_t aRowIdx, bool* aIsSelected) {
177 NS_ENSURE_ARG_POINTER(aIsSelected);
178 *aIsSelected = false;
180 if (!Intl()) return NS_ERROR_FAILURE;
182 if (aRowIdx < 0 || static_cast<uint32_t>(aRowIdx) >= Intl()->RowCount()) {
183 return NS_ERROR_INVALID_ARG;
186 *aIsSelected = Intl()->IsRowSelected(aRowIdx);
187 return NS_OK;
190 NS_IMETHODIMP
191 xpcAccessibleTable::IsCellSelected(int32_t aRowIdx, int32_t aColIdx,
192 bool* aIsSelected) {
193 NS_ENSURE_ARG_POINTER(aIsSelected);
194 *aIsSelected = false;
196 if (!Intl()) return NS_ERROR_FAILURE;
198 if (aRowIdx < 0 || static_cast<uint32_t>(aRowIdx) >= Intl()->RowCount() ||
199 aColIdx < 0 || static_cast<uint32_t>(aColIdx) >= Intl()->ColCount()) {
200 return NS_ERROR_INVALID_ARG;
203 *aIsSelected = Intl()->IsCellSelected(aRowIdx, aColIdx);
204 return NS_OK;
207 NS_IMETHODIMP
208 xpcAccessibleTable::GetSelectedCellCount(uint32_t* aSelectedCellCount) {
209 NS_ENSURE_ARG_POINTER(aSelectedCellCount);
210 *aSelectedCellCount = 0;
212 if (!Intl()) return NS_ERROR_FAILURE;
214 *aSelectedCellCount = Intl()->SelectedCellCount();
215 return NS_OK;
218 NS_IMETHODIMP
219 xpcAccessibleTable::GetSelectedColumnCount(uint32_t* aSelectedColumnCount) {
220 NS_ENSURE_ARG_POINTER(aSelectedColumnCount);
221 *aSelectedColumnCount = 0;
223 if (!Intl()) return NS_ERROR_FAILURE;
225 *aSelectedColumnCount = Intl()->SelectedColCount();
226 return NS_OK;
229 NS_IMETHODIMP
230 xpcAccessibleTable::GetSelectedRowCount(uint32_t* aSelectedRowCount) {
231 NS_ENSURE_ARG_POINTER(aSelectedRowCount);
232 *aSelectedRowCount = 0;
234 if (!Intl()) return NS_ERROR_FAILURE;
236 *aSelectedRowCount = Intl()->SelectedRowCount();
237 return NS_OK;
240 NS_IMETHODIMP
241 xpcAccessibleTable::GetSelectedCells(nsIArray** aSelectedCells) {
242 NS_ENSURE_ARG_POINTER(aSelectedCells);
243 *aSelectedCells = nullptr;
245 if (!Intl()) return NS_ERROR_FAILURE;
247 nsresult rv = NS_OK;
248 nsCOMPtr<nsIMutableArray> selCells =
249 do_CreateInstance(NS_ARRAY_CONTRACTID, &rv);
250 NS_ENSURE_SUCCESS(rv, rv);
252 AutoTArray<Accessible*, XPC_TABLE_DEFAULT_SIZE> cellsArray;
253 Intl()->SelectedCells(&cellsArray);
255 uint32_t totalCount = cellsArray.Length();
256 for (uint32_t idx = 0; idx < totalCount; idx++) {
257 Accessible* cell = cellsArray.ElementAt(idx);
258 selCells->AppendElement(static_cast<nsIAccessible*>(ToXPC(cell)));
261 NS_ADDREF(*aSelectedCells = selCells);
262 return NS_OK;
265 NS_IMETHODIMP
266 xpcAccessibleTable::GetSelectedCellIndices(nsTArray<uint32_t>& aCellsArray) {
267 if (!Intl()) return NS_ERROR_FAILURE;
269 Intl()->SelectedCellIndices(&aCellsArray);
271 return NS_OK;
274 NS_IMETHODIMP
275 xpcAccessibleTable::GetSelectedColumnIndices(nsTArray<uint32_t>& aColsArray) {
276 if (!Intl()) return NS_ERROR_FAILURE;
278 Intl()->SelectedColIndices(&aColsArray);
280 return NS_OK;
283 NS_IMETHODIMP
284 xpcAccessibleTable::GetSelectedRowIndices(nsTArray<uint32_t>& aRowsArray) {
285 if (!Intl()) return NS_ERROR_FAILURE;
287 Intl()->SelectedRowIndices(&aRowsArray);
289 return NS_OK;
292 NS_IMETHODIMP
293 xpcAccessibleTable::GetColumnIndexAt(int32_t aCellIdx, int32_t* aColIdx) {
294 NS_ENSURE_ARG_POINTER(aColIdx);
295 *aColIdx = -1;
297 if (!Intl()) return NS_ERROR_FAILURE;
299 if (aCellIdx < 0 || static_cast<uint32_t>(aCellIdx) >=
300 Intl()->RowCount() * Intl()->ColCount()) {
301 return NS_ERROR_INVALID_ARG;
304 *aColIdx = Intl()->ColIndexAt(aCellIdx);
305 return NS_OK;
308 NS_IMETHODIMP
309 xpcAccessibleTable::GetRowIndexAt(int32_t aCellIdx, int32_t* aRowIdx) {
310 NS_ENSURE_ARG_POINTER(aRowIdx);
311 *aRowIdx = -1;
313 if (!Intl()) return NS_ERROR_FAILURE;
315 if (aCellIdx < 0 || static_cast<uint32_t>(aCellIdx) >=
316 Intl()->RowCount() * Intl()->ColCount()) {
317 return NS_ERROR_INVALID_ARG;
320 *aRowIdx = Intl()->RowIndexAt(aCellIdx);
321 return NS_OK;
324 NS_IMETHODIMP
325 xpcAccessibleTable::GetRowAndColumnIndicesAt(int32_t aCellIdx, int32_t* aRowIdx,
326 int32_t* aColIdx) {
327 NS_ENSURE_ARG_POINTER(aRowIdx);
328 *aRowIdx = -1;
329 NS_ENSURE_ARG_POINTER(aColIdx);
330 *aColIdx = -1;
332 if (!Intl()) return NS_ERROR_FAILURE;
334 if (aCellIdx < 0 || static_cast<uint32_t>(aCellIdx) >=
335 Intl()->RowCount() * Intl()->ColCount()) {
336 return NS_ERROR_INVALID_ARG;
339 Intl()->RowAndColIndicesAt(aCellIdx, aRowIdx, aColIdx);
340 return NS_OK;
343 NS_IMETHODIMP
344 xpcAccessibleTable::GetSummary(nsAString& aSummary) {
345 if (!Intl()) return NS_ERROR_FAILURE;
347 nsAutoString summary;
348 Intl()->Summary(summary);
349 aSummary.Assign(summary);
351 return NS_OK;
354 NS_IMETHODIMP
355 xpcAccessibleTable::IsProbablyForLayout(bool* aResult) {
356 NS_ENSURE_ARG_POINTER(aResult);
357 *aResult = false;
358 if (!Intl()) return NS_ERROR_FAILURE;
360 *aResult = Intl()->IsProbablyLayoutTable();
361 return NS_OK;