Skip to main content

Spellchecking using CSpell

The Markdown and TypeScript files are automatically checked using CSpell. The configuration is in cspell.json

Manually checking spelling

Spellchecking can be manually done on the entire codebase by running yarn spellcheck --all, or on one or more files using yarn spellcheck /path/to/file

Precommit hook

The precommit hook will automatically check spelling on newly committed files.

Ignoring words

There are two ways to ignore words:

Using the word list

Simply add the word to the last word list in packages/tools/cspell/dictionary?.txt.

Please note that there cannot be more than 400 (maybe 500) words in those lists. Beyond this, CSpell will fail loading them and will no longer highlight words in VSCode. If the last dictionary contains more than 400 words, create a new one, and add a reference to it in cspell.json.

Using comments

You can ignore a block of code by wrapping it in // cSpell:disable / // cSpell:enable.

Only do this when there's a large block of code that contains many words to be ignored. Otherwise prefer the word list because it means we don't pollute the code with additional comments.

Also do this when the words to be ignored are not actually words. One example is encrypted data because we don't want to add random meaningless strings to the word list.

By ignoring paths or regexes

In cspell.json, use the ignore properties to skip certain files or folders, or to ignore text that matches a particular regex. For example, "\[.*?\]\(https:\/\/github.com\/.*?\)" is used to ignore all usernames in the changelogs.

Visual Studio Code Extension

The Code Spell Checker extension can be installed to automatically underline spelling mistakes. It will use the project cspell.json file.