Bug 384426. Description relations not getting exposed. r=surkov

This commit is contained in:
aaronleventhal@moonset.net 2007-06-30 13:23:16 -07:00
parent b67791778f
commit abe7a44dfe
2 changed files with 52 additions and 27 deletions

View File

@ -1730,7 +1730,8 @@ nsresult nsAccessible::GetTextFromRelationID(nsIAtom *aIDAttrib, nsString &aName
nsIContent*
nsAccessible::FindNeighbourPointingToNode(nsIContent *aForNode,
nsIAtom *aTagName, nsIAtom *aAttr,
nsIAtom *aTagName, nsIAtom *aRelationAttr,
PRUint32 aRelationNameSpaceID,
PRUint32 aAncestorLevelsToSearch)
{
nsCOMPtr<nsIContent> binding;
@ -1785,8 +1786,8 @@ nsAccessible::FindNeighbourPointingToNode(nsIContent *aForNode,
return nsnull;
if (content != prevSearched) {
labelContent = FindDescendantPointingToID(&controlID, content, aAttr,
nsnull, kNameSpaceID_None,
labelContent = FindDescendantPointingToID(&controlID, content, aRelationAttr,
aRelationNameSpaceID, nsnull,
aTagName);
}
}
@ -1794,28 +1795,28 @@ nsAccessible::FindNeighbourPointingToNode(nsIContent *aForNode,
}
labelContent = FindDescendantPointingToID(&controlID, aForNode,
aAttr, prevSearched,
kNameSpaceID_None, aTagName);
aRelationAttr, aRelationNameSpaceID,
prevSearched, aTagName);
prevSearched = aForNode;
}
return labelContent;
}
// Pass in aForAttrib == nsnull if any <label> will do
// Pass in aRelationAttr == nsnull if any <label> will do
nsIContent*
nsAccessible::FindDescendantPointingToID(const nsAString *aId,
nsIContent *aLookContent,
nsIAtom *aForAttrib,
nsIAtom *aRelationAttr,
PRUint32 aRelationNameSpaceID,
nsIContent *aExcludeContent,
PRUint32 aForAttribNameSpace,
nsIAtom *aTagType)
{
if (!aTagType || aLookContent->Tag() == aTagType) {
if (aForAttrib) {
// Check for ID in the attribute aForAttrib, which can be a list
if (aRelationAttr) {
// Check for ID in the attribute aRelationAttr, which can be a list
nsAutoString idList;
if (aLookContent->GetAttr(aForAttribNameSpace, aForAttrib, idList)) {
if (aLookContent->GetAttr(aRelationNameSpaceID, aRelationAttr, idList)) {
idList.Insert(' ', 0); // Surround idlist with spaces for search
idList.Append(' ');
nsAutoString id(*aId);
@ -1841,12 +1842,12 @@ nsAccessible::FindDescendantPointingToID(const nsAString *aId,
while ((child = aLookContent->GetChildAt(count++)) != nsnull) {
if (child != aExcludeContent) {
labelContent = FindDescendantPointingToID(aId, child, aForAttrib,
aExcludeContent,
aForAttribNameSpace, aTagType);
}
if (labelContent) {
return labelContent;
labelContent = FindDescendantPointingToID(aId, child, aRelationAttr,
aRelationNameSpaceID, aExcludeContent,
aTagType);
if (labelContent) {
return labelContent;
}
}
}
return nsnull;
@ -2531,6 +2532,7 @@ NS_IMETHODIMP nsAccessible::GetAccessibleBelow(nsIAccessible **_retval)
already_AddRefed<nsIDOMNode>
nsAccessible::FindNeighbourPointingToThis(nsIAtom *aRelationAttr,
PRUint32 aRelationNameSpaceID,
PRUint32 aAncestorLevelsToSearch)
{
nsIContent *content = GetRoleContent(mDOMNode);
@ -2539,6 +2541,7 @@ nsAccessible::FindNeighbourPointingToThis(nsIAtom *aRelationAttr,
nsIContent* description = FindNeighbourPointingToNode(content, nsnull,
aRelationAttr,
aRelationNameSpaceID,
aAncestorLevelsToSearch);
if (!description)
@ -2580,6 +2583,7 @@ NS_IMETHODIMP nsAccessible::GetAccessibleRelated(PRUint32 aRelationType, nsIAcce
if (relatedID.IsEmpty()) {
const PRUint32 kAncestorLevelsToSearch = 3;
relatedNode = FindNeighbourPointingToThis(nsAccessibilityAtoms::labelledby,
kNameSpaceID_WAIProperties,
kAncestorLevelsToSearch);
}
break;
@ -2612,6 +2616,7 @@ NS_IMETHODIMP nsAccessible::GetAccessibleRelated(PRUint32 aRelationType, nsIAcce
const PRUint32 kAncestorLevelsToSearch = 3;
relatedNode =
FindNeighbourPointingToThis(nsAccessibilityAtoms::describedby,
kNameSpaceID_WAIProperties,
kAncestorLevelsToSearch);
if (!relatedNode && content->Tag() == nsAccessibilityAtoms::description &&
@ -2626,12 +2631,14 @@ NS_IMETHODIMP nsAccessible::GetAccessibleRelated(PRUint32 aRelationType, nsIAcce
}
case nsIAccessibleRelation::RELATION_NODE_CHILD_OF:
{
relatedNode = FindNeighbourPointingToThis(nsAccessibilityAtoms::owns);
relatedNode = FindNeighbourPointingToThis(nsAccessibilityAtoms::owns,
kNameSpaceID_WAIProperties);
break;
}
case nsIAccessibleRelation::RELATION_CONTROLLED_BY:
{
relatedNode = FindNeighbourPointingToThis(nsAccessibilityAtoms::controls);
relatedNode = FindNeighbourPointingToThis(nsAccessibilityAtoms::controls,
kNameSpaceID_WAIProperties);
break;
}
case nsIAccessibleRelation::RELATION_CONTROLLER_FOR:
@ -2648,7 +2655,8 @@ NS_IMETHODIMP nsAccessible::GetAccessibleRelated(PRUint32 aRelationType, nsIAcce
}
case nsIAccessibleRelation::RELATION_FLOWS_FROM:
{
relatedNode = FindNeighbourPointingToThis(nsAccessibilityAtoms::flowto);
relatedNode = FindNeighbourPointingToThis(nsAccessibilityAtoms::flowto,
kNameSpaceID_WAIProperties);
break;
}

View File

@ -167,7 +167,21 @@ protected:
// Relation helpers
nsresult GetTextFromRelationID(nsIAtom *aIDAttrib, nsString &aName);
/**
* Search element in neighborhood of the given element by tag name and
* attribute value that equals to ID attribute of the current element.
* ID attribute can be either 'id' attribute or 'anonid' if the element is
* anonymous.
*
* @param aRelationAttr - attribute name of searched element
* @param aRelationNamespaceID - namespace id of searched attribute, by default
* empty namespace
* @param aAncestorLevelsToSearch - points how is the neighborhood of the
* given element big.
*/
already_AddRefed<nsIDOMNode> FindNeighbourPointingToThis(nsIAtom *aRelationAttr,
PRUint32 aRelationNameSpaceID = kNameSpaceID_None,
PRUint32 aAncestorLevelsToSearch = 0);
/**
@ -178,13 +192,16 @@ protected:
*
* @param aForNode - the given element the search is performed for
* @param aTagName - tag name of searched element
* @param aAttr - attribute name of searched element
* @param aRelationAttr - attribute name of searched element
* @param aRelationNamespaceID - namespace id of searched attribute, by default
* empty namespace
* @param aAncestorLevelsToSearch - points how is the neighborhood of the
* given element big.
*/
static nsIContent *FindNeighbourPointingToNode(nsIContent *aForNode,
nsIAtom *aTagName,
nsIAtom *aAttr,
nsIAtom *aRelationAttr,
PRUint32 aRelationNameSpaceID = kNameSpaceID_None,
PRUint32 aAncestorLevelsToSearch = 5);
/**
@ -194,17 +211,17 @@ protected:
*
* @param aId - value of searched attribute
* @param aLookContent - element that search is performed inside
* @param aForAttrib - searched attribute
* @param aRelationAttr - searched attribute
* @param aRelationNamespaceID - namespace id of searched attribute, by default
* empty namespace
* @param aExcludeContent - element that is skiped for search
* @param aForAttribNamespace - namespace id of searched attribute, by default
* empty namespace
* @param aTagType - tag name of searched element, by default it is 'label'
*/
static nsIContent *FindDescendantPointingToID(const nsAString *aId,
nsIContent *aLookContent,
nsIAtom *forAttrib,
nsIAtom *aRelationAttr,
PRUint32 aRelationNamespaceID = kNameSpaceID_None,
nsIContent *aExcludeContent = nsnull,
PRUint32 aForAttribNamespace = kNameSpaceID_None,
nsIAtom *aTagType = nsAccessibilityAtoms::label);
static nsIContent *GetHTMLLabelContent(nsIContent *aForNode);