Use "= default" to denote default constructor or destructor
[WebKit-https.git] / Source / WebCore / accessibility / AccessibilityARIAGridRow.cpp
1 /*
2  * Copyright (C) 2009 Apple Inc. All rights reserved.
3  *
4  * Redistribution and use in source and binary forms, with or without
5  * modification, are permitted provided that the following conditions
6  * are met:
7  *
8  * 1.  Redistributions of source code must retain the above copyright
9  *     notice, this list of conditions and the following disclaimer.
10  * 2.  Redistributions in binary form must reproduce the above copyright
11  *     notice, this list of conditions and the following disclaimer in the
12  *     documentation and/or other materials provided with the distribution.
13  * 3.  Neither the name of Apple Inc. ("Apple") nor the names of
14  *     its contributors may be used to endorse or promote products derived
15  *     from this software without specific prior written permission.
16  *
17  * THIS SOFTWARE IS PROVIDED BY APPLE AND ITS CONTRIBUTORS "AS IS" AND ANY
18  * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
19  * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
20  * DISCLAIMED. IN NO EVENT SHALL APPLE OR ITS CONTRIBUTORS BE LIABLE FOR ANY
21  * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
22  * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
23  * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
24  * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
25  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
26  * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
27  */
28
29 #include "config.h"
30 #include "AccessibilityARIAGridRow.h"
31
32 #include "AccessibilityObject.h"
33 #include "AccessibilityTable.h"
34 #include "RenderObject.h"
35
36 namespace WebCore {
37     
38 AccessibilityARIAGridRow::AccessibilityARIAGridRow(RenderObject* renderer)
39     : AccessibilityTableRow(renderer)
40 {
41 }
42
43 AccessibilityARIAGridRow::~AccessibilityARIAGridRow() = default;
44
45 Ref<AccessibilityARIAGridRow> AccessibilityARIAGridRow::create(RenderObject* renderer)
46 {
47     return adoptRef(*new AccessibilityARIAGridRow(renderer));
48 }
49
50 bool AccessibilityARIAGridRow::isARIATreeGridRow() const
51 {
52     AccessibilityObject* parent = parentTable();
53     if (!parent)
54         return false;
55     
56     return parent->isTreeGrid();
57 }
58     
59 void AccessibilityARIAGridRow::disclosedRows(AccessibilityChildrenVector& disclosedRows)
60 {
61     // The contiguous disclosed rows will be the rows in the table that 
62     // have an aria-level of plus 1 from this row.
63     AccessibilityObject* parent = parentObjectUnignored();
64     if (!is<AccessibilityTable>(*parent) || !downcast<AccessibilityTable>(*parent).isExposableThroughAccessibility())
65         return;
66     
67     // Search for rows that match the correct level. 
68     // Only take the subsequent rows from this one that are +1 from this row's level.
69     int index = rowIndex();
70     if (index < 0)
71         return;
72     
73     unsigned level = hierarchicalLevel();
74     auto& allRows = downcast<AccessibilityTable>(*parent).rows();
75     int rowCount = allRows.size();
76     for (int k = index + 1; k < rowCount; ++k) {
77         AccessibilityObject* row = allRows[k].get();
78         // Stop at the first row that doesn't match the correct level.
79         if (row->hierarchicalLevel() != level + 1)
80             break;
81
82         disclosedRows.append(row);
83     }
84 }
85     
86 AccessibilityObject* AccessibilityARIAGridRow::disclosedByRow() const
87 {
88     // The row that discloses this one is the row in the table
89     // that is aria-level subtract 1 from this row.
90     AccessibilityObject* parent = parentObjectUnignored();
91     if (!is<AccessibilityTable>(*parent) || !downcast<AccessibilityTable>(*parent).isExposableThroughAccessibility())
92         return nullptr;
93     
94     // If the level is 1 or less, than nothing discloses this row.
95     unsigned level = hierarchicalLevel();
96     if (level <= 1)
97         return nullptr;
98     
99     // Search for the previous row that matches the correct level.
100     int index = rowIndex();
101     auto& allRows = downcast<AccessibilityTable>(parent)->rows();
102     int rowCount = allRows.size();
103     if (index >= rowCount)
104         return nullptr;
105     
106     for (int k = index - 1; k >= 0; --k) {
107         AccessibilityObject* row = allRows[k].get();
108         if (row->hierarchicalLevel() == level - 1)
109             return row;
110     }
111     
112     return nullptr;
113 }
114     
115 AccessibilityObject* AccessibilityARIAGridRow::parentObjectUnignored() const
116 {
117     return parentTable();
118 }
119     
120 AccessibilityTable* AccessibilityARIAGridRow::parentTable() const
121 {
122     // The parent table might not be the direct ancestor of the row unfortunately. ARIA states that role="grid" should
123     // only have "row" elements, but if not, we still should handle it gracefully by finding the right table.
124     for (AccessibilityObject* parent = parentObject(); parent; parent = parent->parentObject()) {
125         // The parent table for an ARIA grid row should be an ARIA table.
126         if (is<AccessibilityTable>(*parent)) {
127             AccessibilityTable& tableParent = downcast<AccessibilityTable>(*parent);
128             if (tableParent.isExposableThroughAccessibility() && tableParent.isAriaTable())
129                 return &tableParent;
130         }
131     }
132     
133     return nullptr;
134 }
135
136 AccessibilityObject* AccessibilityARIAGridRow::headerObject()
137 {
138     for (const auto& child : children()) {
139         if (child->ariaRoleAttribute() == RowHeaderRole)
140             return child.get();
141     }
142     
143     return nullptr;
144 }
145
146 } // namespace WebCore