Bug 92389 - Writer: Comment text not accessible with screen reader
Summary: Writer: Comment text not accessible with screen reader
Status: NEW
Alias: None
Product: LibreOffice
Classification: Unclassified
Component: Writer (show other bugs)
Version:
(earliest affected)
Inherited From OOo
Hardware: All All
: medium normal
Assignee: Not Assigned
URL:
Whiteboard: target:24.8.0 target:24.2.2
Keywords: accessibility
: 106180 135439 (view as bug list)
Depends on:
Blocks: a11y, Accessibility Writer-Comments
  Show dependency treegraph
 
Reported: 2015-06-27 21:21 UTC by sunrisingsoul
Modified: 2024-08-24 20:19 UTC (History)
11 users (show)

See Also:
Crash report or crash signature:


Attachments
Screenshot of Writer comment hierarchy in Accerciser (167.12 KB, image/png)
2021-10-12 08:16 UTC, Michael Weghorn
Details
Sample doc used for creating Accerciser screenshot (16.12 KB, application/vnd.oasis.opendocument.text)
2021-10-12 08:18 UTC, Michael Weghorn
Details

Note You need to log in before you can comment on or make changes to this bug.
Description sunrisingsoul 2015-06-27 21:21:28 UTC
When composing a document, and the user wishes to add a comment, once you press the Control+Alt+C keybinding to add a comment to a highlighted portion of text, or to a area of text that is proceeding the cursor, Orca does not interact with the comment field. Arrowing through the text typed out provides no speech output. Deleting text does not provide speech output.

Activating the menu item under Insert, Comment, yields the same result.

Using the Control + Alt + Page Up and Page Down functions to cycle through comments only reads the text written out for that particular area that is commented, does not allow navigation to the actual comment itself with orca.

Perhaps provide a keybinding that will get to the list of comments presented should there already be some?
Comment 1 Robinson Tryon (qubit) 2015-12-10 03:37:41 UTC Comment hidden (obsolete)
Comment 2 raal 2016-05-11 16:55:52 UTC
I can confirm with Version: 5.2.0.0.alpha1+
Build ID: eb7593daa4bac21bd68182c8bbbd3ee3bd7b64dd
CPU Threads: 4; OS Version: Linux 4.4; UI Render: default; 
TinderBox: Linux-rpm_deb-x86_64@70-TDF, Branch:master, Time: 2016-05-03_07:06:45
Comment 3 Alex ARNAUD 2016-07-06 14:24:02 UTC
Dear all,

with the latest Orca (3.20.2) and latest LibrOffice fresh (5.1.4) the problem continues to appear.

Best regards.
Comment 4 Aron Budea 2016-07-27 08:56:24 UTC
*** Bug 101002 has been marked as a duplicate of this bug. ***
Comment 5 Yousuf Philips (jay) (retired) 2016-09-10 23:42:34 UTC
Confirmed with 5.2.1 on windows with NVDA.
Comment 6 Quentin Christensen 2017-10-26 03:24:16 UTC
This issue still exsits in LibreOffice 5.4.2.2 (x64) using NVDA 2017.3.

Issue on NVDA issue tracker: https://github.com/nvaccess/nvda/issues/7700
Comment 7 QA Administrators 2018-10-27 02:55:34 UTC Comment hidden (obsolete)
Comment 8 Patrick ZAJDA 2019-02-25 17:21:45 UTC
I can confirm with version 6.3.0.0.alpha0+
Build ID: 4187b2beaa3d1294cd5c76ec0b662f3f4fadc421
Threads CPU : 12; OS : Linux 4.19; UI Render : par défaut; VCL: gtk3; 
TinderBox: Linux-rpm_deb-x86_64@86-TDF, Branch:master, Time: 2019-02-25_07:04:36
Locale : fr-FR (fr_FR.UTF-8); Langue IHM : fr-FR
Calc: threaded
Comment 9 Timur 2021-01-20 08:26:25 UTC
*** Bug 106180 has been marked as a duplicate of this bug. ***
Comment 10 Timur 2021-01-20 09:19:08 UTC
*** Bug 135439 has been marked as a duplicate of this bug. ***
Comment 11 Christophe Strobbe 2021-10-09 13:17:16 UTC
I have looked at the bugs that have been marked as a duplicate of this one or that are indirectly linked to it:
* Bug 92389 - Writer: Comment text not accessible with screen reader 
  Reported without reference to a specific OS; confirmed both on Linux with Orca (until 2019) and on Windows with NVDA (2017).
* Bug 99261 - Calc: Comment not supported with screen reader
  Reported for Windows (tested with both Jaws and NVDA); confirmed on Linux with Orca
* Bug 101002 - Comments in Impress are not accessible (adding/reading)
  Reported for Linux with Orca; comments mention both keyboard interaction problems and missing accessibility metadata (checked using accerciser).
* Bug 102054 - Allow access and modifying of comment with keyboard
  Reported without reference to a specific OS; bug focuses on keyboard interaction
* Bug 102058 - No screen reader notification that there is a comment
  Reported without reference to a specific OS; confirmed on Linux with Orca (until 2018).
* Bug 106180 - No screen reader notification that there is a comment
  Reported without reference to a specific OS (but split off from bug 102058); confirmed on Linux with Orca (2018).
* Bug 135439 - Accessibility: No output from screenreader when adding a comment in Writer 
  Reported for Windows (with unidentified screen reader); confirmed on Linux and repeatedly on Windows.

Based on the above reports, the bug seems to be caused by two issues: 
(1) missing role information in the accessibility API (see issues 92389, 102058, 106180 and 135439) and 
(2) the absence of keyboard accessibility (originally reported in 99261 and contradicted there, but see my findings below).

My findings regarding keyboard access are the following: In LibreOffice Writer, you can indeed insert a comment using either the shortcuts Crtl + Alt + C or through the menu items Insert -> Comment; you can get out of the comment using Esc. However, editing an existing comment later on appears to be impossible: you can browse the list of existing comments in the Navigator, but pressing Enter on a specific comment takes you to the document's text, not to the comment.
(In LibreOffice Calc, you can open an existing comment again when you press Shift + F10 to open the cell's context menu and then choosing "Edit comment". This does not work in Writer or Impress. In addition, you exit a comment in Writer or Calc by pressing Esc, whereas this does not seem to work in Impress, where I use F6.)

I am not 100% certain what the exposed accessibility role should be; the closest match seems to be IA2_ROLE_NOTE in IAccessible2 and ROLE_COMMENT in ATK/AT-SPI. See the "Role Mapping Table" in "Core Accessibility API Mappings 1.1" at https://www.w3.org/TR/core-aam-1.1/#mapping_role_table

Question:
Linux, Windows and Mac OS use different accessibility APIs. Should there be just one open bug for this issue in spite of this? Or one for the Windows version and one for Linux (and perhaps another one for Mac OS)?
Comment 12 V Stuart Foote 2021-10-09 13:57:08 UTC
@Michael W, another a11y issue you might enjoy quashing, similar to the table cell roles, has additional accessible role tweaks needed. Stuart
Comment 13 Michael Weghorn 2021-10-12 08:16:55 UTC
Created attachment 175683 [details]
Screenshot of Writer comment hierarchy in Accerciser
Comment 14 Michael Weghorn 2021-10-12 08:18:03 UTC
Created attachment 175684 [details]
Sample doc used for creating Accerciser screenshot
Comment 15 Michael Weghorn 2021-10-12 09:30:24 UTC
For Writer, a good starting point to further look into this is 'sw/source/uibase/docvw/SidebarWinAcc.cxx', which contains the a11y implementation for 'SwAnnotationWin'.

Navigating through the hierachy of the attached sample doc, attachment 175684 [details], in Accerciser (using LO with gtk3 VCL plugin in Linux) reveals that "something" is already exposed to AT, s. the node with role "comment" and its children as well as my comments in the Accerciser screenshot, attachment 175683 [details]. This presumably needs to be improved further.

(In reply to V Stuart Foote from comment #12)
> @Michael W, another a11y issue you might enjoy quashing, similar to the
> table cell roles, has additional accessible role tweaks needed. Stuart

@Stuart: Thanks. I can't really look further into this at this point, but maybe I'll find some time at some point in the future, yet can't promise anything. (In general, I'm subscribed to the a11y meta bugs and hope to find some time to take a look at one or the other bug at some point.)

(In reply to Christophe Strobbe from comment #11)
> I have looked at the bugs that have been marked as a duplicate of this one
> or that are indirectly linked to it:
> [...]
> 
> Question:
> Linux, Windows and Mac OS use different accessibility APIs. Should there be
> just one open bug for this issue in spite of this? Or one for the Windows
> version and one for Linux (and perhaps another one for Mac OS)?

Thanks for the detailed analysis! I'd say having one bug for all platforms is fine for now. Should a solution only be implemented for one platform at first, we can still open a follow-up bug for the remaining ones.
Comment 16 Michael Weghorn 2021-10-14 06:39:35 UTC
(In reply to Quentin Christensen from comment #6)
> This issue still exsits in LibreOffice 5.4.2.2 (x64) using NVDA 2017.3.
> 
> Issue on NVDA issue tracker: https://github.com/nvaccess/nvda/issues/7700

And there's also https://github.com/nvaccess/nvda/issues/11684, referring to bug 135439 which has been closed as a duplicate of this one here.
Comment 17 orborneee 2023-07-21 03:20:08 UTC Comment hidden (spam)
Comment 18 Stéphane Guillou (stragu) 2024-02-11 05:53:10 UTC
Same in OOo 3.3: characters read aloud by Orca when entered, but not when navigating existing text with cursor.

Still current in recent trunk build:

Version: 24.8.0.0.alpha0+ (X86_64) / LibreOffice Community
Build ID: 4d381b54d1c598c181b4a21a8bf0db86eb4668d1
CPU threads: 8; OS: Linux 5.15; UI render: default; VCL: gtk3
Locale: en-AU (en_AU.UTF-8); UI: en-US
Calc: threaded
Comment 19 Michael Weghorn 2024-02-14 14:24:38 UTC
(In reply to Stéphane Guillou (stragu) from comment #18)
> Same in OOo 3.3: characters read aloud by Orca when entered, but not when
> navigating existing text with cursor.

I can reproduce that with single-line comments.

Interestingly, text *is* announced by the screen reader for me when having comments with multiple paragraphs in them.

Example:
1) start Orca
2) open attachment 175684 [details]
3) click into the comment using the mouse -> comment not read out
4) move cursor using the arrow keys on the keyboard -> comment not read out
5) move to end of the comment text, press Enter and then type "Hello world"
6) click into document
7) repeat steps 3-5 -> text is now read out just fine

step 6 is optional.

Maybe this is not only about single/multi line, but when creating a new doc with new comments, multiline ones are also announced, single line ones are not.

Version: 24.8.0.0.alpha0+ (X86_64) / LibreOffice Community
Build ID: 1db5b87fe69c2375f1d66974dafcd563303c76db
CPU threads: 12; OS: Linux 6.6; UI render: default; VCL: gtk3
Locale: en-GB (en_GB.UTF-8); UI: en-US
Calc: threaded
Comment 20 Commit Notification 2024-02-16 08:12:01 UTC
Michael Weghorn committed a patch related to this issue.
It has been pushed to "master":

https://git.libreoffice.org/core/commit/512b09ec51cfbe9bb0ce1a7f229b443dc427f6f3

tdf#92389 sw a11y: Use SolarMutex in SidebarWinAccessibleContext

It will be available in 24.8.0.

The patch should be included in the daily builds available at
https://dev-builds.libreoffice.org/daily/ in the next 24-48 hours. More
information about daily builds can be found at:
https://wiki.documentfoundation.org/Testing_Daily_Builds

Affected users are encouraged to test the fix and report feedback.
Comment 21 Michael Weghorn 2024-02-16 08:14:17 UTC
(In reply to Michael Weghorn from comment #19)
> Maybe this is not only about single/multi line, but when creating a new doc
> with new comments, multiline ones are also announced, single line ones are
> not.

When looking into this a bit more, it actually wasn't just about single/multi line, but something else seems to play a role also.

The commit from comment 20 doesn't fix the overall issue, but only a related crash I ran into.
Comment 22 Commit Notification 2024-02-16 10:09:32 UTC
Michael Weghorn committed a patch related to this issue.
It has been pushed to "libreoffice-24-2":

https://git.libreoffice.org/core/commit/cc88d26c8ebcf1dd828469eead40d7747f2b9129

tdf#92389 sw a11y: Use SolarMutex in SidebarWinAccessibleContext

It will be available in 24.2.2.

The patch should be included in the daily builds available at
https://dev-builds.libreoffice.org/daily/ in the next 24-48 hours. More
information about daily builds can be found at:
https://wiki.documentfoundation.org/Testing_Daily_Builds

Affected users are encouraged to test the fix and report feedback.
Comment 23 Adriani90 2024-05-16 11:20:40 UTC
Testing with NVDA 2024.1 in LO 24.8, I confirm this works only when there is more than one paragraph. When there is only one line of text in the document and I try to comment, I press ctrl+alt+c, NVDA does not announce that I am in an edit field for the comment.
Pressing left and right arrow, NVDA is silent.
Pressing up and down arrow, NVDA pronounces the word I makred for commenting, in my case "hello"

I get following in the log:

```
IO - inputCore.InputManager.executeGesture (13:02:14.337) - winInputHook (17340):
Input: kb(laptop):rightArrow
DEBUG - editableText.EditableText._hasCaretMoved (13:02:14.347) - MainThread (27580):
Caret move detected using bookmarks. Elapsed 0 sec, retries 0
IO - speech.speech.speak (13:02:14.367) - MainThread (27580):
Speaking [CharacterModeCommand(True), ' ', EndUtteranceCommand()]
IO - inputCore.InputManager.executeGesture (13:02:14.733) - winInputHook (17340):
Input: kb(laptop):leftArrow
DEBUG - editableText.EditableText._hasCaretMoved (13:02:14.757) - MainThread (27580):
Caret move detected using event. Elapsed 0 sec, retries 0
IO - speech.speech.speak (13:02:14.757) - MainThread (27580):
Speaking [CharacterModeCommand(True), 'o', EndUtteranceCommand()]
IO - inputCore.InputManager.executeGesture (13:02:20.257) - winInputHook (17340):
Input: kb(laptop):alt+control+c
DEBUGWARNING - NVDAObjects.IAccessible.IAccessible._get_IAccessibleRole (13:02:20.297) - MainThread (27580):
accRole failed: (-2147467259, 'Unbekannter Fehler', (None, None, None, 0, None))
DEBUGWARNING - NVDAObjects.IAccessible.IAccessible._get_IAccessibleRole (13:02:20.307) - MainThread (27580):
accRole failed: (-2147467259, 'Unbekannter Fehler', (None, None, None, 0, None))
DEBUGWARNING - NVDAObjects.IAccessible.IAccessible._get_IAccessibleRole (13:02:20.307) - MainThread (27580):
accRole failed: (-2147467259, 'Unbekannter Fehler', (None, None, None, 0, None))
DEBUGWARNING - NVDAObjects.IAccessible.IAccessible._get_IAccessibleRole (13:02:20.307) - MainThread (27580):
accRole failed: (-2147467259, 'Unbekannter Fehler', (None, None, None, 0, None))
DEBUGWARNING - NVDAObjects.IAccessible.IAccessible._get_IAccessibleRole (13:02:20.310) - MainThread (27580):
accRole failed: (-2147467259, 'Unbekannter Fehler', (None, None, None, 0, None))
DEBUGWARNING - NVDAObjects.IAccessible.IAccessible._get_IAccessibleRole (13:02:20.310) - MainThread (27580):
accRole failed: (-2147467259, 'Unbekannter Fehler', (None, None, None, 0, None))
DEBUGWARNING - NVDAObjects.IAccessible.IAccessible._get_IAccessibleRole (13:02:20.310) - MainThread (27580):
accRole failed: (-2147467259, 'Unbekannter Fehler', (None, None, None, 0, None))
DEBUGWARNING - NVDAObjects.IAccessible.IAccessible._get_IAccessibleRole (13:02:20.310) - MainThread (27580):
accRole failed: (-2147467259, 'Unbekannter Fehler', (None, None, None, 0, None))
DEBUGWARNING - NVDAObjects.IAccessible.IAccessible._get_IAccessibleRole (13:02:20.310) - MainThread (27580):
accRole failed: (-2147467259, 'Unbekannter Fehler', (None, None, None, 0, None))
DEBUGWARNING - NVDAObjects.IAccessible.IAccessible._get_IA2Attributes (13:02:21.058) - MainThread (27580):
IAccessibleObject.attributes COMError (-2147467259, 'Unbekannter Fehler', (None, None, None, 0, None))
IO - inputCore.InputManager.executeGesture (13:02:21.299) - winInputHook (17340):
Input: kb(laptop):leftArrow
DEBUG - editableText.EditableText._hasCaretMoved (13:02:21.407) - MainThread (27580):
Caret didn't move before timeout. Elapsed: 0.10781 sec
IO - speech.speech.speak (13:02:21.410) - MainThread (27580):
Speaking [CharacterModeCommand(True), ' ', EndUtteranceCommand()]
IO - inputCore.InputManager.executeGesture (13:02:21.672) - winInputHook (17340):
Input: kb(laptop):leftArrow
DEBUG - editableText.EditableText._hasCaretMoved (13:02:21.777) - MainThread (27580):
Caret didn't move before timeout. Elapsed: 0.100092 sec
IO - speech.speech.speak (13:02:21.782) - MainThread (27580):
Speaking [CharacterModeCommand(True), ' ', EndUtteranceCommand()]
IO - inputCore.InputManager.executeGesture (13:02:21.847) - winInputHook (17340):
Input: kb(laptop):leftArrow
DEBUG - editableText.EditableText._hasCaretMoved (13:02:21.957) - MainThread (27580):
Caret didn't move before timeout. Elapsed: 0.109795 sec
```

When I use the menu to access the comment area, I get similar bahavior:

Sometimes, when accessing the comment edit field, I get following error and NVDA is tottally silent when I press the arrow keys to navigate through the comment:
```
IO - inputCore.InputManager.executeGesture (13:11:03.916) - winInputHook (17340):
Input: kb(laptop):upArrow
IO - speech.speech.speak (13:11:03.946) - MainThread (27580):
Speaking ['Kommentar einfügen\tStrg+Alt+C', CancellableSpeech (still valid)]
DEBUGWARNING - NVDAObjects.IAccessible.IAccessible._getIA2RelationFirstTarget (13:11:03.946) - MainThread (27580):
Unable to use _getIA2TargetsForRelationsOfType, fallback to _IA2Relations.
IO - inputCore.InputManager.executeGesture (13:11:04.946) - winInputHook (17340):
Input: kb(laptop):enter
IO - speech.speech.speak (13:11:05.016) - MainThread (27580):
Speaking ['Unbenannt 1 – LibreOfficeDev Writer', CancellableSpeech (still valid)]
IO - speech.speech.speak (13:11:05.016) - MainThread (27580):
Speaking ['Unbenannt 1 - LibreOfficeDev-Dokument', 'Dokument', 'einstellbar', CancellableSpeech (still valid)]
IO - speech.speech.speak (13:11:05.016) - MainThread (27580):
Speaking ['Hello', ' ']
ERROR - eventHandler.executeEvent (13:11:05.066) - MainThread (27580):
error executing event: gainFocus on <NVDAObjects.IAccessible.IAccessible object at 0x011F1330> with extra args of {}
Traceback (most recent call last):
  File "eventHandler.pyc", line 322, in executeEvent
  File "eventHandler.pyc", line 355, in doPreGainFocus
  File "api.pyc", line 189, in setFocusObject
  File "api.pyc", line 338, in setNavigatorObject
  File "documentBase.pyc", line 74, in makeTextInfo
  File "compoundDocuments.pyc", line 254, in __init__
  File "documentBase.pyc", line 74, in makeTextInfo
  File "textInfos\offsets.pyc", line 478, in __init__
  File "textInfos\offsets.pyc", line 257, in _getCaretOffset
NotImplementedError
DEBUGWARNING - NVDAObjects.IAccessible.IAccessible._get_IA2Attributes (13:11:05.555) - MainThread (27580):
IAccessibleObject.attributes COMError (-2147467259, 'Unbekannter Fehler', (None, None, None, 0, None))
IO - inputCore.InputManager.executeGesture (13:11:06.766) - winInputHook (17340):
Input: kb(laptop):leftArrow
IO - inputCore.InputManager.executeGesture (13:11:07.290) - winInputHook (17340):
Input: kb(laptop):rightArrow
IO - inputCore.InputManager.executeGesture (13:11:07.496) - winInputHook (17340):
Input: kb(laptop):rightArrow
IO - inputCore.InputManager.executeGesture (13:11:07.706) - winInputHook (17340):
Input: kb(laptop):leftArrow
IO - inputCore.InputManager.executeGesture (13:11:08.139) - winInputHook (17340):
Input: kb(laptop):downArrow
IO - inputCore.InputManager.executeGesture (13:11:08.379) - winInputHook (17340):
Input: kb(laptop):upArrow
IO - inputCore.InputManager.executeGesture (13:11:08.565) - winInputHook (17340):
Input: kb(laptop):upArrow
```
Comment 24 Adriani90 2024-05-16 11:26:52 UTC
I seems there is a 0xfffc object replacement character rendered in the document when a comment is added and I navigate with NVDA character by character. Is that character intentional? It is also rendered within a word if the comment is added in the middle of a word.
Users will wonder why there are many empty characters when navigating a document with many comments. 
The replacement characters also break the word by word navigation.
Comment 25 Michael Weghorn 2024-08-24 20:19:53 UTC
(In reply to Adriani90 from comment #24)
> I seems there is a 0xfffc object replacement character rendered in the
> document when a comment is added and I navigate with NVDA character by
> character. Is that character intentional? It is also rendered within a word
> if the comment is added in the middle of a word.

Don't have much experience with that yet, but from a first glance, I suspect yes. From how I understand it so far, that character is used to indicate that there is an object, and further information about that object should then be retrievable via the Hyperlink interface.
(There are tdf#77679 and tdf#35107 about that not working properly yet, though, at least on Linux with AT-SPI.)

I also see that character in use by Mozilla Firefox on Windows.

Demonstrating that in NVDA's Python console with the sample HTML doc mentioned below, with the web document in Firefox being the focus object initially:

    >>> focus
    <NVDAObjects.Dynamic_DocumentMozillaIAccessible object at 0x0167ADB0>
    >>> focus.role
    <Role.DOCUMENT: 52>
    >>> focus.childCount
    2
    >>> focus.children[0]
    <NVDAObjects.IAccessible.mozilla.Mozilla object at 0x06C05D50>
    >>> firstParagraph = focus.children[0]
    >>> firstParagraph.role
    <Role.PARAGRAPH: 47>
    >>> firstParagraph.IAccessibleTextObject.text(0, -1)
    'This is some paragraph with a  . '
    >>> firstParagraph.IAccessibleTextObject.text(0, -1)[-2]
    '.'
    >>> firstParagraph.IAccessibleTextObject.text(0, -1)[-3]
    ' '
    >>> ord(firstParagraph.IAccessibleTextObject.text(0, -1)[-3])
    65532
    >>> hex(ord(firstParagraph.IAccessibleTextObject.text(0, -1)[-3]))
    '0xfffc'

Sample doc:

<html>
<body>
<p>
	This is some paragraph with a <a href="https://www.example.org/"> link </a>.
</p>
<p>
	This is another paragraph, without any link.
</p>

</body>
</html>