Introducing Accessible Scala

Thursday 14 June 2018

Guillaume Massé

Scala is proudly a welcoming environment for all. The Scala Center is demonstrating this by supporting the development of Accessible Scala, a tool for blind and partially-sighted developers (see SCP-016 by Sam Halliday). One of its goals is to remove the noise introduced by various delimiters. The current solution with text-to-speech engine, would read

def foo[A: Wibble](s: String, b: Wobble[A]): Int = ...


def space foo open square bracket capital a colon space
wibble close square bracket open bracket s colon space
string comma space b colon space wobble open square bracket
capital a close square bracket close bracket colon
space Int space equals space ...

Indeed such a description is necessary to enable precision editing.

However, the following would convey the same information more efficiently:

def foo parameterized with: A context bounded by: Wibble. s String, b Wobble of A returns: Int

Since there is more than one way to pronounce Scala source code, we are open to the community proposition. You can find an extensive test case here: DescribeTest.scala. If you find that descriptions could be improved, send us a pull request with the expected form.

Reading Scala out loud makes some of its syntactic elements less intimidating for beginners. There is no more need to mentally associate the syntax +T with its concept co-variant. It can also help sighted developers to describe Scala orally, for example in the context of pair programming. However, notice in the example above, how the type parameter delimiters: [ and ] are absent from the verbal description. When expressions get more complex, the audible form can become ambiguous or difficult to decipher.

To overcome the limitation of verbal description, we created a technique called the Cursor. The idea is simple: from your cursor location, you can navigate the abstract syntax tree of the source code. From a node, you can navigate to the parent node, to the siblings (left or right) or the first child. As you navigate the code, it’s described verbally and selected. Here is an illustrated example, the arrows (→ exp ←) represents the highlighted text and Alt + Arrow the keyboard shortcut applied to navigate.

→ private ← class A { // speaks: "private"
  val a = 1

Alt + Right

private class → A ← { // speaks: "A"
  val a = 1

Alt + Down

private class A {
  → val a = 1 ← // speaks: "val a equals 1"

We created an online demo (adjust your volume!) to let you try the cursor technique and hear the descriptions.

Want to try it?

You can try it now on your web browser via your online demo! (Tip: It works best on Google Chrome! )

We also created a vscode extension, so you can try on your project. Search for Accessible Scala in the extension manager

Hello world demo Coverage demo

What’s next?

We hope you are excited as we are by the online demo. We would like to hear your feedback on the verbal descriptions. We would like to invite the Scala community to improve the quality of the project and join the effort by improving the descriptions. You can create a PR against DescribeTest.scala. Another area where we would need help is to create an integration with Emacspeak. It’s an emacs plugin widely used by blind developers. If you know emacs lisp well and want to participate, please reach out to us!

Talk to us!

Thoughts or opinions about Accessible Scala? Join us over on Scala Contributors to contribute to the discussion. We also have a gitter channel.