-
-
Notifications
You must be signed in to change notification settings - Fork 654
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
NVDA reading out words it shouldn't if 'speak typed words' is on #10331
Comments
NVDA (as well as almost all other screen readers) is able to log nearly all typed keys if the log level is set to "Input/Output" or "Debug". Therefore I suggest to completely disable it if you don't need it. The default log level is "Info". Typed keys aren't logged on that level. |
Thanks, although even with log level disabled the behaviour I mentioned persists. So I would still like to have this here as a bug report. NVDA should only speak out the words that are typed into a text field. It should neither speak, nor retain any memory of characters that are typed 'into the ether' (unless if the relevant logging options are set). |
I can reproduce this issue in NVDA alpha-18874,6cdb7be0 |
This behavior also exists with NVDA 2018.1 on win7x64 (quick test in Windows Explorer). (I hate such keyboard input speech echo feedbacks. Therefore I disable them all in every screen reader.) |
I can confirm that tis issue persists with NVDA version 2020.2 Beta 1. I tested this quickly on the Desktop on a Windows 8.1 system. As far as my memory goes, I have been experiencing this behaviour since many, many years, probably as far back as 2015. Hence, I am fairly certain that this is not a newly introduced regression. |
Looking at how this is implemented, it appears NVDA is attempting to speak typed words in any given control, whatever its role is, until the control looses focus. I guess this is done to avoid missing to announce typed words in unknown controls. IMHO, this could be change to trigger announce of typed words only for the following roles:
@michaelDCurran do you think this is worth giving a reasonable try, or can you think of cases where this would lead to a regression? |
cc: @seanbudd, @gerald-hartig can you please prioritize this accordingly? This has indeed security implications, especially when typing letters of a password accidentally in a non edit field and the speak typed characters or typed words is on. |
It's worth noting that when NVDA detects a freeze (watchdog), NVDA still reports typed words in some situations. The consequence in real life is that sometimes I have had passwords reported when typing them because NVDA was in a short freeze state while typing a password. cc @gerald-hartig for awareness |
No. Assuming a password field is marked correctly by the application, NVDA explicitly detects this and does not store or report the typed characters (unless full i/o logging is enabled, but that would only be done for debugging purposes and is not enabled by default).
watchdog shouldn't act unless an app has been frozen for more than 10 seconds. The only time this delay is shortened is if you are switching foreground windows, but in that case, typing a password without waiting for speech isn't a great idea anyway, since you can't be certain you are typing into a password field. Can you provide more details about the scenarios in which this occurs? All of that said, it should be fairly straightforward to:
|
It happens when I connect on the webpage of my e-mail provider's webpage (https://www.laposte.net/accueil):
Since I know the page and am used to it, I do not expect to hear the role of the control being focused. I type username, Enter, password and Enter without waiting for an audio feedback. |
And, I will add that @CyrilleB79's usage pattern here, is not at all uncommon among skilled users.
When 90% of the time you know what is going to be said after performing a certain action, you often want to make up speed there that you will likely later lose in other tasks where you do have to listen.
|
That's fine, but that isn't a foreground window switch, which means it shouldn't be a watchdog freeze recovery (see my comment above for the reasons). So something else is going on there that isn't related to watchdog. That doesn't invalidate the issue, but it does mean it needs additional diagnosis. |
It may just be that the focus events take a while to arrive and your key presses get buffered until that happens. But I don't really know what we can do about that because when your key presses occurred, the username field probably still had focus as far as NVDA was concerned, so even if we disabled typed words for most things, you'd still hit this problem. The pattern of ignoring output is common among skilled users, yes, but when it comes to passwords, all users (even sighted ones) accept a certain amount of risk if they just start typing without checking to see that their password is actually being masked. Perhaps when you press enter, the username doesn't submit immediately and your typed characters actually end up going into the username field. |
No, the characters of the password are (or may be) echoed. But I can confirm that these characters end up in the password field that has just appeared, because the password check is OK. |
Fixes #16848, related #10331, #3027 Summary of the issue: Currently NVDA can only toggle typing echo (characters and words) on or off globally. Users want more granular control to only have typing feedback in edit controls, while keeping it off in other contexts like listss or non-edit areas. Description of user facing changes - Added a new option "Only in edit controls" for both "Speak typed characters" and "Speak typed words" settings in Keyboard Settings - Instead of checkboxes, these are now combo boxes with three options: - Off: No typing echo - Only in edit controls: Only echo text typed in edit fields - Always: Echo all typed text - By default, "Speak typed characters" is now set to "Only in edit controls". - Updated relevant documentation in the user guide Description of development approach The implementation: 1. Added a TypingEcho enum in configFlags.py with values: - OFF (0) - EDIT_CONTROLS (1) - ALWAYS (2) 2. Changed keyboard typing echo configuration from boolean to integer values 3. Updated speech.py, behaviors.py and inputComposition.py to use the new enum 4. Modified settings dialog to use combo box instead of checkbox 5. Updated documentation Testing strategy: Tested the following scenarios: 1. Basic functionality: - Open Notepad (edit control) - Set to "Only in edit controls" - Type text - should be announced - Verify both character and word echo settings - Explorer file lists(non-edit control) - Type text - should not be announced - Test all three modes (Off, On, Only in edit controls) 2. Different contexts: - Web browser input fields - Rich text editors - Read-only text areas - Terminal windows Known issues with pull request: None identified.
Hello, #17505 is merged, can this be closed as well? |
Thanks @cary-rowen yes this issue is now fixed with #17505. Closing. |
Win 10 / NVDA portable 2019.2 / Laptop layout
Hello. with the title setting on I notice the following odd behaviour. If I click on an empty area on the desktop and press some keys, for example "xyz" then space, NVDA will rread out "xyz" as if this was a text document and I had typed these four keys.
This happens in other apps. For example in File Explorer if I press "a" and no file begins with "a", then press space, I hear that "a" being read out.
In NVDA's own speech viewer I can type characters into the read-only output, press space and hear them read back.
This doesn't seem to happen when the pressed key has a legitimate effect. For example, if I press "a" in FileExplorer and there actually is a file beginning with "a" for the focus to move to, then when I press space I won't hear that "a" spoken back to me.
If however there is only one file beginning with "a", and I press "a" three times then space, I will hear two "a"s. If there are two files then I can press "a" multiple times and not hear any of them read back to me when I press space.
Narrator didn't do this. It only spoke the words I had typed if they were typed into a valid text box.
It has also gotten me a bit worried for security reasons. If NVDA can read out the "hello" I typed into the desktop, or its own speech viewer, then clearly that "hello" I typed must be being stored somewhere. Do I need to worry about password security for instance?
Thanks.
The text was updated successfully, but these errors were encountered: