diff options
author | Balazs Varga <balazs.varga.extern@allotropia.de> | 2024-09-17 14:32:20 +0200 |
---|---|---|
committer | Thorsten Behrens <thorsten.behrens@allotropia.de> | 2024-09-17 18:04:38 +0200 |
commit | b7a49b42d612e2bd65c38f5a3da4c67f7ceca20e (patch) | |
tree | 4f9ab633788abd3b9a5b66fed8ad849b97a50615 | |
parent | 85d7d20444b0eee9a542846f06eff8813811e3a6 (diff) |
tdf#162988 - A11Y sidebar: fix hyperlinks false warning
cib_contract49c-24.2.6.2.M2
Better to check the SwpHints of the textnodes then iterate
through on the xParagraph's xTextRanges to search for a11y
hyperlink warnings.
Change-Id: I19a3eddd53f122bd4290e5b93e4784b89f65427d
Reviewed-on: https://gerrit.libreoffice.org/c/core/+/173563
Reviewed-by: Thorsten Behrens <thorsten.behrens@allotropia.de>
Tested-by: allotropia jenkins <jenkins@allotropia.de>
-rw-r--r-- | sw/qa/core/accessibilitycheck/data/HyperlinkTest.odt | bin | 8663 -> 11092 bytes | |||
-rw-r--r-- | sw/source/core/access/AccessibilityCheck.cxx | 86 |
2 files changed, 40 insertions, 46 deletions
diff --git a/sw/qa/core/accessibilitycheck/data/HyperlinkTest.odt b/sw/qa/core/accessibilitycheck/data/HyperlinkTest.odt Binary files differindex 1eba1932ce21..92240fb1d67f 100644 --- a/sw/qa/core/accessibilitycheck/data/HyperlinkTest.odt +++ b/sw/qa/core/accessibilitycheck/data/HyperlinkTest.odt diff --git a/sw/source/core/access/AccessibilityCheck.cxx b/sw/source/core/access/AccessibilityCheck.cxx index 83ff5de88ff1..96260cc19a95 100644 --- a/sw/source/core/access/AccessibilityCheck.cxx +++ b/sw/source/core/access/AccessibilityCheck.cxx @@ -370,42 +370,48 @@ public: class HyperlinkCheck : public NodeCheck { private: - void checkTextRange(uno::Reference<text::XTextRange> const& xTextRange, SwTextNode* pTextNode, - sal_Int32 nStart) + void checkHyperLinks(SwTextNode* pTextNode) { - uno::Reference<beans::XPropertySet> xProperties(xTextRange, uno::UNO_QUERY); - if (!xProperties->getPropertySetInfo()->hasPropertyByName("HyperLinkURL")) - return; - - OUString sHyperlink; - xProperties->getPropertyValue("HyperLinkURL") >>= sHyperlink; - if (!sHyperlink.isEmpty()) + const OUString& sParagraphText = pTextNode->GetText(); + SwpHints& rHints = pTextNode->GetSwpHints(); + for (size_t i = 0; i < rHints.Count(); ++i) { - OUString sText = xTextRange->getString(); - INetURLObject aHyperlink(sHyperlink); - std::shared_ptr<sw::AccessibilityIssue> pIssue; - if (aHyperlink.GetProtocol() != INetProtocol::NotValid - && INetURLObject(sText) == aHyperlink) + const SwTextAttr* pTextAttr = rHints.Get(i); + if (pTextAttr->Which() == RES_TXTATR_INETFMT) { - OUString sIssueText - = SwResId(STR_HYPERLINK_TEXT_IS_LINK).replaceFirst("%LINK%", sHyperlink); - pIssue = lclAddIssue(m_rIssueCollection, sIssueText, - sfx::AccessibilityIssueID::HYPERLINK_IS_TEXT); - } - else if (sText.getLength() <= 5) - { - pIssue = lclAddIssue(m_rIssueCollection, SwResId(STR_HYPERLINK_TEXT_IS_SHORT), - sfx::AccessibilityIssueID::HYPERLINK_SHORT); - } + OUString sHyperlink = pTextAttr->GetINetFormat().GetValue(); + if (!sHyperlink.isEmpty()) + { + INetURLObject aHyperlink(sHyperlink); + std::shared_ptr<sw::AccessibilityIssue> pIssue; + sal_Int32 nStart = pTextAttr->GetStart(); + OUString sRunText = sParagraphText.copy(nStart, *pTextAttr->GetEnd() - nStart); - if (pIssue) - { - pIssue->setIssueObject(IssueObject::TEXT); - pIssue->setNode(pTextNode); - SwDoc& rDocument = pTextNode->GetDoc(); - pIssue->setDoc(rDocument); - pIssue->setStart(nStart); - pIssue->setEnd(nStart + sText.getLength()); + if (aHyperlink.GetProtocol() != INetProtocol::NotValid + && INetURLObject(sRunText) == aHyperlink) + { + OUString sIssueText = SwResId(STR_HYPERLINK_TEXT_IS_LINK) + .replaceFirst("%LINK%", sHyperlink); + pIssue = lclAddIssue(m_rIssueCollection, sIssueText, + sfx::AccessibilityIssueID::HYPERLINK_IS_TEXT); + } + else if (sRunText.getLength() <= 5) + { + pIssue + = lclAddIssue(m_rIssueCollection, SwResId(STR_HYPERLINK_TEXT_IS_SHORT), + sfx::AccessibilityIssueID::HYPERLINK_SHORT); + } + + if (pIssue) + { + pIssue->setIssueObject(IssueObject::TEXT); + pIssue->setNode(pTextNode); + SwDoc& rDocument = pTextNode->GetDoc(); + pIssue->setDoc(rDocument); + pIssue->setStart(nStart); + pIssue->setEnd(nStart + sRunText.getLength()); + } + } } } } @@ -422,21 +428,9 @@ public: return; SwTextNode* pTextNode = pCurrent->GetTextNode(); - rtl::Reference<SwXParagraph> xParagraph - = SwXParagraph::CreateXParagraph(pTextNode->GetDoc(), pTextNode, nullptr); - if (!xParagraph.is()) - return; - - uno::Reference<container::XEnumeration> xRunEnum = xParagraph->createEnumeration(); - sal_Int32 nStart = 0; - while (xRunEnum->hasMoreElements()) + if (pTextNode->HasHints()) { - uno::Reference<text::XTextRange> xRun(xRunEnum->nextElement(), uno::UNO_QUERY); - if (xRun.is()) - { - checkTextRange(xRun, pTextNode, nStart); - nStart += xRun->getString().getLength(); - } + checkHyperLinks(pTextNode); } } }; |