On Accessibility of Plain Text Files 1.0 Writing for screen readers and conventional readers line 18 1.1 Linearize line 28 1.2 Visually similar characters line 41 1.3 Indentation line 50 2.0 Graphical and tabular information line 63 2.1 Graphs and trees line 69 2.2 Tables line 80 3.0 Thanks line 95 Terminal applications and plain text files are potentially quite accessible, despite the inherent lack of metadata for screen readers and navigational aids. On cause of the lack of metadata, which also is plain text's greatest strength, it is quite easy to make a mess of it all. These are my notes on the matter. 1.0 Writing for screen readers and conventional readers Text should (most of the time?) be easily accessible to as many as practically possible. This means trying to write in a straightforward manner for the intended audience as well as avoiding 'leet spelling and ASCII graphics. ASCII graphics will just be an unskippable wall of "pipe-underscore-pipe" and so on to the screen reader. It also means tabular data should not be presented in some huge, drawn table. 1.1 Linearize I asked Devin Prater some questions on how to check for the quality of terminal output for screen readers, one of the answers were "Really, reading it linearly is the best way. Screen readers read from left to right, top to bottom. Blind people can read the output line by line, word by word, character by character, but that's about it. [...]" In other words, I think if the output makes sense if you read it out loud to somebody who can not see the terminal window, you are probably on the right track. 1.2 Visually similar characters Stick strictly to the semantic meaning of the character. Mixing alphabets may look cute, but the screen reader really does not care about the levity of exchanging Latin capital letter X with Cyrillic capital letter HA. This problem becomes even worse when mixing Kanji into Western languages for decorative purposes. 1.3 Indentation Again, I quote the information mr Prater gave me "[...] often, blind people don't have the reporting of indentation turned on. Some screen readers, like NVDA on Windows or Orca on Linux, can report indentation, while others, like VoiceOver on Mac (because of course Swift doesn't need it so no other programming languages need it right? /s) and ChromeVox, don't report it. So it doesn't hurt, but I probably won't get the semantic info." In other words, indentation is OK to help somebody who navigates the file visually, but it should not be necessary to make sense of the file. 2.0 Graphical and tabular information Diagrams, directed graphs, trees, etc, these are all commonly shown in a way which depend on a graphical presentation, even in terminals. 2.1 Graphs and trees This is the advice I got from Devin Prater on directed graphs verbatim: "I'd say showing what connects to what, or just narratively describing the graph, would be the best option. Describing it would probably take less manual typing, and you may be able to do it programmatically." Again, we return to "Can you read it out loud?" and "Don't make it all overly complicated." The latter of course holds any time anyway. 2.2 Tables For tables, I use the advice from HTML tables: Present the legend textually. Remember relevant units, hearing "square kilometres" repeated once for every number makes it easy to lose track of what is important or relevant. Stick to few columns. If hearing a large table read out loud, myself I would prefer multiple tables and just two columns each over some huge table where navigating linearly gets harder and harder for each column added. Also, few columns is a lot more robust for those using a conventional terminal, especially if they have to use a view with few columns of characters. 3.0 Thanks Thank you to Devin Prater (@devinprater@devin.masto.host) for answering my questions regarding sanity checking, graphs and indentation. Earlier edited 20220127T204733Z, 20220730T175231Z. Simplified formatting. 20230929T195527Z, 26A05487