{"id":13600816,"url":"https://github.com/iamcco/coc-spell-checker","last_synced_at":"2025-04-04T19:14:45.032Z","repository":{"id":43983566,"uuid":"141995927","full_name":"iamcco/coc-spell-checker","owner":"iamcco","description":"A basic spell checker that works well with camelCase code for (Neo)vim","archived":false,"fork":false,"pushed_at":"2023-10-16T00:37:59.000Z","size":660,"stargazers_count":267,"open_issues_count":43,"forks_count":13,"subscribers_count":3,"default_branch":"master","last_synced_at":"2025-03-28T18:17:19.370Z","etag":null,"topics":["camelcase","coc","coc-nvim","neovim","spell-checker","vim"],"latest_commit_sha":null,"homepage":"","language":"TypeScript","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"mit","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/iamcco.png","metadata":{"files":{"readme":"README.md","changelog":"CHANGELOG.md","contributing":null,"funding":null,"license":"License.txt","code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null,"governance":null,"roadmap":null,"authors":null},"funding":{"custom":"https://github.com/iamcco/markdown-preview.nvim#buy-me-a-coffee-%EF%B8%8F"}},"created_at":"2018-07-23T09:58:25.000Z","updated_at":"2025-02-28T12:54:16.000Z","dependencies_parsed_at":"2024-01-16T09:55:48.462Z","dependency_job_id":"386d4c60-ae1f-4c65-8798-ecbb26239bef","html_url":"https://github.com/iamcco/coc-spell-checker","commit_stats":{"total_commits":18,"total_committers":5,"mean_commits":3.6,"dds":"0.33333333333333337","last_synced_commit":"51c484169de17b5317e54f5cf06bcd3fb04477e7"},"previous_names":[],"tags_count":0,"template":false,"template_full_name":null,"repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/iamcco%2Fcoc-spell-checker","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/iamcco%2Fcoc-spell-checker/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/iamcco%2Fcoc-spell-checker/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/iamcco%2Fcoc-spell-checker/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/iamcco","download_url":"https://codeload.github.com/iamcco/coc-spell-checker/tar.gz/refs/heads/master","host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":247234923,"owners_count":20905854,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2022-07-04T15:15:14.044Z","host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":["camelcase","coc","coc-nvim","neovim","spell-checker","vim"],"created_at":"2024-08-01T18:00:49.285Z","updated_at":"2025-04-04T19:14:45.015Z","avatar_url":"https://github.com/iamcco.png","language":"TypeScript","funding_links":["https://github.com/iamcco/markdown-preview.nvim#buy-me-a-coffee-%EF%B8%8F"],"categories":["Language Support","TypeScript"],"sub_categories":[],"readme":"# Spelling Checker for (Neo)vim\n\n\u003e fork from [vscode-spell-checker](https://github.com/streetsidesoftware/vscode-spell-checker) v1.7.24\nand [commit](https://github.com/streetsidesoftware/vscode-spell-checker/commit/f9c2a9eabf3bc41f19d2d0216472afd003fa65bb)\n\nA basic spell checker that works well with camelCase code.\n\nThe goal of this spell checker is to help catch common spelling errors while keeping\nthe number of false positives low.\n\n## Functionality\n\nLoad a TypeScript, JavaScript, Text, etc. file.  Words not in the dictionary\nfiles will have a squiggly underline.\n\n![screenshot](https://user-images.githubusercontent.com/5492542/71676618-9e86f380-2dbb-11ea-9838-2291e895c7ff.png)\n\nTo see the list of suggestions:\n\n![screenshot](https://user-images.githubusercontent.com/5492542/71676668-bc545880-2dbb-11ea-8bcc-4bd9140ef959.png)\n\nPaste below configurations to your `init.vim` or `.vimrc`\n\n- Remap for do codeAction of selected region\n\n  ``` vim\n  vmap \u003cleader\u003ea \u003cPlug\u003e(coc-codeaction-selected)\n  nmap \u003cleader\u003ea \u003cPlug\u003e(coc-codeaction-selected)\n  ```\n\nThen positioning the cursor in the word, any of the following should\ndisplay the list of suggestions:\n\n- `\u003cleader\u003eaap` for current paragraph\n- `\u003cleader\u003eaw` for current word\n\nOr use the [coc-actions](https://github.com/iamcco/coc-actions)\n\n![image](https://user-images.githubusercontent.com/5492542/71774253-78717700-2fa6-11ea-9629-1e88d0b5114e.png)\n\n## Install\n\n`:CocInstall coc-spell-checker`\n\n### Commands and Configurations\n\n- [commands](https://github.com/iamcco/coc-spell-checker/blob/master/package.json#L30)\n- [configurations](https://github.com/iamcco/coc-spell-checker/blob/master/package.json#L125)\n\n## Supported Languages\n\n- English (US)\n- English (GB) - turn on by changing `\"cSpell.language\": \"en\"` to\n`\"cSpell.language\": \"en-GB\"`\n\n## Add-On Dictionaries\n\n- [catalan](https://github.com/iamcco/coc-cspell-dicts)\n- [czech](https://github.com/iamcco/coc-cspell-dicts)\n- [danish](https://github.com/iamcco/coc-cspell-dicts)\n- [dutch](https://github.com/iamcco/coc-cspell-dicts)\n- [french](https://github.com/iamcco/coc-cspell-dicts)\n- [french-reforme](https://github.com/iamcco/coc-cspell-dicts)\n- [german](https://github.com/iamcco/coc-cspell-dicts)\n- [greek](https://github.com/iamcco/coc-cspell-dicts)\n- [italian](https://github.com/iamcco/coc-cspell-dicts)\n- [persian](https://github.com/iamcco/coc-cspell-dicts)\n- [polish](https://github.com/iamcco/coc-cspell-dicts)\n- [portuguese](https://github.com/iamcco/coc-cspell-dicts)\n- [portuguese-brazilian](https://github.com/iamcco/coc-cspell-dicts)\n- [russian](https://github.com/iamcco/coc-cspell-dicts)\n- [spanish](https://github.com/iamcco/coc-cspell-dicts)\n- [swedish](https://github.com/iamcco/coc-cspell-dicts)\n- [turkish](https://github.com/iamcco/coc-cspell-dicts)\n- [ukrainian](https://github.com/iamcco/coc-cspell-dicts)\n- [medical-terms](https://github.com/iamcco/coc-cspell-dicts)\n\n## Enabled File Types\n\n- vim\n- AsciiDoc\n- C, C++\n- C#\n- css, less, scss\n- Elixir\n- Go\n- Html\n- Java\n- JavaScript\n- JSON / JSONC\n- LaTex\n- Markdown\n- PHP\n- PowerShell\n- Pug / Jade\n- Python\n- reStructuredText\n- Rust\n- Scala\n- Text\n- TypeScript\n- YAML\n\n## How it works with camelCase\n\nThe concept is simple, split camelCase words before checking them against\na list of known English words.\n\n- camelCase -\u003e camel case\n- HTMLInput -\u003e html input -- Notice that the `I` is associated with `Input` and not `HTML`\n- snake_case_words -\u003e snake case words\n- camel2snake -\u003e camel snake -- (the 2 is ignored)\n\n### Special case will ALL CAPS words\n\nThere are a few special cases to help will common spelling practices for\nALL CAPS words.\n\nTrailing `s`, `ing`, `ies`, `es`, `ed` are kept with the previous word.\n\n- CURLs -\u003e curls -- trailing `s`\n- CURLedRequest -\u003e curled request -- trailing `ed`\n\n## Things to note\n\n- This spellchecker is case insensitive.  It will not catch errors like\nenglish which should be English.\n- The spellchecker uses a local word dictionary.  It does not send anything\noutside your machine.\n- The words in the dictionary can and do contain errors.\n- There are missing words.\n- Only words longer than 3 characters are checked.  \"jsj\" is ok, while \"jsja\"\nis not.\n- All symbols and punctuation are ignored.\n\n## In Document Settings\n\nIt is possible to add spell check settings into your source code.\nThis is to help with file specific issues that may not be applicable to the\nentire project.\n\nAll settings are prefixed with `cSpell:` or `spell-checker:`.\n\n- `disable` -- turn off the spell checker for a section of code.\n- `enable` -- turn the spell checker back on after it has been turned off.\n- `ignore` -- specify a list of words to be ignored.\n- `words` -- specify a list of words to be considered correct and will appear\nin the suggestions list.\n- `ignoreRegExp` -- Any text matching the regular expression will NOT be checked\nfor spelling.\n- `includeRegExp` -- Only text matching the collection of includeRegExp will be checked.\n- `enableCompoundWords` / `disableCompoundWords` -- Allow / disallow words\nlike: \"stringlength\".\n\n### Enable / Disable checking sections of code\n\nIt is possible to disable / enable the spell checker by adding comments to your code.\n\n#### Disable Checking\n\n- `/* cSpell:disable */`\n- `/* spell-checker: disable */`\n- `/* spellchecker: disable */`\n- `/* cspell: disable-line */`\n- `/* cspell: disable-next-line */`\n\n#### Enable Checking\n\n- `/* cSpell:enable */`\n- `/* spell-checker: enable */`\n- `/* spellchecker: enable */`\n\n#### Example\n\n``` javascript\n\n// cSpell:disable\nconst wackyWord = ['zaallano', 'wooorrdd', 'zzooommmmmmmm'];\n/* cSpell:enable */\n\n// Nest disable / enable is not Supported\n\n// spell-checker:disable\n// It is now disabled.\n\nvar liep = 1;\n\n/* cspell:disable */\n// It is still disabled\n\n// cSpell:enable\n// It is now enabled\n\nconst str = \"goededag\";  // \u003c- will be flagged as an error.\n\n// spell-checker:enable \u003c- doesn't do anything\n\n// cSPELL:DISABLE \u003c-- also works.\n\n// if there isn't an enable, spelling is disabled till the end of the file.\nconst str = \"goedemorgen\";  // \u003c- will NOT be flagged as an error.\n\n```\n\u003c!--- cSpell:enable --\u003e\n\n### Ignore\n\nIgnore allows you the specify a list of words you want to ignore within the document.\n\n```javascript\n// cSpell:ignore zaallano, wooorrdd\n// cSpell:ignore zzooommmmmmmm\nconst wackyWord = ['zaallano', 'wooorrdd', 'zzooommmmmmmm'];\n```\n\n**Note:** words defined with `ignore` will be ignored for the entire file.\n\n### Words\n\nThe words list allows you to add words that will be considered correct and will be used as suggestions.\n\n```javascript\n// cSpell:words woorxs sweeetbeat\nconst companyName = 'woorxs sweeetbeat';\n```\n\n**Note:** words defined with `words` will be used for the entire file.\n\n### Enable / Disable compound words\n\nIn some programing language it is common to glue words together.\n\n```c\n// cSpell:enableCompoundWords\nchar * errormessage;  // Is ok with cSpell:enableCompoundWords\nint    errornumber;   // Is also ok.\n```\n\n**Note:** Compound word checking cannot be turned on / off in the same file.\nThe last setting in the file determines the value for the entire file.\n\n### Excluding and Including Text to be checked.\n\nBy default, the entire document is checked for spelling.\n`cSpell:disable`/`cSpell:enable` above allows you to block off sections of the document.\n`ignoreRegExp` and `includeRegExp` give you the ability to ignore or include patterns of text.\nBy default the flags `gim` are added if no flags are given.\n\nThe spell checker works in the following way:\n\n1. Find all text matching `includeRegExp`\n2. Remove any text matching `excludeRegExp`\n3. Check the remaining text.\n\n#### Exclude Example\n\n```javascript\n// cSpell:ignoreRegExp 0x[0-9a-f]+     -- will ignore c style hex numbers\n// cSpell:ignoreRegExp /0x[0-9A-F]+/g  -- will ignore upper case c style hex numbers.\n// cSpell:ignoreRegExp g{5} h{5}       -- will only match ggggg, but not hhhhh or 'ggggg hhhhh'\n// cSpell:ignoreRegExp g{5}|h{5}       -- will match both ggggg and hhhhh\n// cSpell:ignoreRegExp /g{5} h{5}/     -- will match 'ggggg hhhhh'\n/* cSpell:ignoreRegExp /n{5}/          -- will NOT work as expected because of the ending comment -\u003e */\n/*\n   cSpell:ignoreRegExp /q{5}/          -- will match qqqqq just fine but NOT QQQQQ\n*/\n// cSpell:ignoreRegExp /[^\\s]{40,}/    -- will ignore long strings with no spaces.\n// cSpell:ignoreRegExp Email           -- this will ignore email like patterns -- see Predefined RegExp expressions\nvar encodedImage = 'HR+cPzr7XGAOJNurPL0G8I2kU0UhKcqFssoKvFTR7z0T3VJfK37vS025uKroHfJ9nA6WWbHZ/ASn...';\nvar email1 = 'emailaddress@myfancynewcompany.com';\nvar email2 = '\u003cemailaddress@myfancynewcompany.com\u003e';\n```\n\n**Note:** ignoreRegExp and includeRegExp are applied to the entire file.  They do not start and stop.\n\n#### Include Example\n\nIn general you should not need to use `includeRegExp`. But if you are mixing languages then it could come in helpful.\n\n```Python\n# cSpell:includeRegExp #.*\n# cSpell:includeRegExp (\"\"\"|''')[^\\1]*\\1\n# only comments and block strings will be checked for spelling.\ndef sum_it(self, seq):\n    \"\"\"This is checked for spelling\"\"\"\n    variabele = 0\n    alinea = 'this is not checked'\n    for num in seq:\n        # The local state of 'value' will be retained between iterations\n        variabele += num\n        yield variabele\n```\n\n\n## Predefined RegExp expressions\n\n### Exclude patterns\n* `Urls`\u003csup\u003e1\u003c/sup\u003e -- Matches urls\n* `HexDigits` -- Matches hex digits: `/^x?[0-1a-f]+$/i`\n* `HexValues` -- Matches common hex format like #aaa, 0xfeef, \\\\u0134\n* `EscapeCharacters`\u003csup\u003e1\u003c/sup\u003e -- matches special characters: '\\\\n', '\\\\t' etc.\n* `Base64`\u003csup\u003e1\u003c/sup\u003e -- matches base64 blocks of text longer than 40 characters.\n* `Email` -- matches most email addresses.\n\n### Include Patterns\n* `Everything`\u003csup\u003e1\u003c/sup\u003e -- By default we match an entire document and remove the excludes.\n* `string` -- This matches common string formats like '...', \"...\", and \\`...\\`\n* `CStyleComment` -- These are C Style comments /* */ and //\n* `PhpHereDoc` -- This matches PHPHereDoc strings.\n\n\u003csup\u003e1.\u003c/sup\u003e These patterns are part of the default include/exclude list for every file.\n\n## Customization\n\n### Adding words to the Workspace Dictionary\n\nYou have the option to add you own words to the workspace dictionary.  The easiest,\nis to put your cursor on the word you wish to add, hit `\u003cleader\u003eaw`  You will get a list\nof suggestions and the option to add the word.\n\nYou can also type in a word you want to add to the dictionary: `:CocCommand cSpell.addWordToDictionary`\nand type in the word you wish to add.\n\n### cSpell.json\n\nWords added to the dictionary are placed in the `cSpell.json` file in the `.vim` folder found in the _workspace_.\nNote, the settings in cSpell.json will override the equivalent cSpell settings in settings.json.\n\n#### Example _cSpell.json_ file\n```javascript\n// cSpell Settings\n{\n    // Version of the setting file.  Always 0.1\n    \"version\": \"0.1\",\n    // language - current active spelling language\n    \"language\": \"en\",\n    // words - list of words to be always considered correct\n    \"words\": [\n        \"mkdirp\",\n        \"tsmerge\",\n        \"githubusercontent\",\n        \"streetsidesoftware\",\n        \"vsmarketplacebadge\",\n        \"visualstudio\"\n    ],\n    // flagWords - list of words to be always considered incorrect\n    // This is useful for offensive words and common spelling errors.\n    // For example \"hte\" should be \"the\"\n    \"flagWords\": [\n        \"hte\"\n    ]\n}\n```\n\n### Configuration Settings\n\n```javascript\n    //-------- Code Spell Checker Configuration --------\n    // The Language local to use when spell checking. \"en\" and \"en-GB\" are currently supported.\n    \"cSpell.language\": \"en\",\n\n    // Controls the maximum number of spelling errors per document.\n    \"cSpell.maxNumberOfProblems\": 100,\n\n    // Controls the number of suggestions shown.\n    \"cSpell.numSuggestions\": 8,\n\n    // The minimum length of a word before checking it against a dictionary.\n    \"cSpell.minWordLength\": 4,\n\n    // Specify file types to spell check.\n    \"cSpell.enabledLanguageIds\": [\n        \"csharp\",\n        \"go\",\n        \"javascript\",\n        \"javascriptreact\",\n        \"markdown\",\n        \"php\",\n        \"plaintext\",\n        \"typescript\",\n        \"typescriptreact\",\n        \"yml\"\n    ],\n\n    // Enable / Disable the spell checker.\n    \"cSpell.enabled\": true,\n\n    // Display the spell checker status on the status bar.\n    \"cSpell.showStatus\": true,\n\n    // Words to add to dictionary for a workspace.\n    \"cSpell.words\": [],\n\n    // Enable / Disable compound words like 'errormessage'\n    \"cSpell.allowCompoundWords\": false,\n\n    // Words to be ignored and not suggested.\n    \"cSpell.ignoreWords\": [\"behaviour\"],\n\n    // User words to add to dictionary.  Should only be in the user settings.\n    \"cSpell.userWords\": [],\n\n    // Specify paths/files to ignore.\n    \"cSpell.ignorePaths\": [\n        \"node_modules\",        // this will ignore anything the node_modules directory\n        \"**/node_modules\",     // the same for this one\n        \"**/node_modules/**\",  // the same for this one\n        \"node_modules/**\",     // Doesn't currently work due to how the current working directory is determined.\n        \"vscode-extension\",    //\n        \".git\",                // Ignore the .git directory\n        \"*.dll\",               // Ignore all .dll files.\n        \"**/*.dll\"             // Ignore all .dll files\n    ],\n\n    // flagWords - list of words to be always considered incorrect\n    // This is useful for offensive words and common spelling errors.\n    // For example \"hte\" should be \"the\"`\n    \"cSpell.flagWords\": [\"hte\"],\n\n    // Set the delay before spell checking the document. Default is 50.\n    \"cSpell.spellCheckDelayMs\": 50,\n```\n\n## Dictionaries\n\nThe spell checker includes a set of default dictionaries.\n\n### General Dictionaries\n\n- **wordsEn** - Derived from Hunspell US English words.\n- **wordsEnGb** - Derived from Hunspell GB English words.\n- **companies** - List of well known companies\n- **softwareTerms** - Software Terms and concepts like \"coroutine\", \"debounce\", \"tree\", etc.\n- **misc** - Terms that do not belong in the other dictionaries.\n\n### Programming Language Dictionaries\n\n- **typescript** - keywords for Typescript and Javascript\n- **node** - terms related to using nodejs.\n- **php** - *php* keywords and library methods\n- **go** - *go* keywords and library methods\n- **python** - *python* keywords\n- **powershell** - *powershell* keywords\n- **html** - *html* related keywords\n- **css** - *css*, *less*, and *scss* related keywords\n\n### Miscellaneous Dictionaries\n\n- **fonts** - long list of fonts - to assist with *css*\n\nBased upon the programming language, different dictionaries will be loaded.\n\nHere are the default rules: \"*\" matches any language.\n`\"local\"` is used to filter based upon the `\"cSpell.language\"` setting.\n\n``` javascript\n{\n\"cSpell.languageSettings\": [\n    { \"languageId\": '*',      \"local\": 'en',               \"dictionaries\": ['wordsEn'] },\n    { \"languageId\": '*',      \"local\": 'en-US',            \"dictionaries\": ['wordsEn'] },\n    { \"languageId\": '*',      \"local\": 'en-GB',            \"dictionaries\": ['wordsEnGb'] },\n    { \"languageId\": '*',                                   \"dictionaries\": ['companies', 'softwareTerms', 'misc'] },\n    { \"languageId\": \"python\", \"allowCompoundWords\": true,  \"dictionaries\": [\"python\"]},\n    { \"languageId\": \"go\",     \"allowCompoundWords\": true,  \"dictionaries\": [\"go\"] },\n    { \"languageId\": \"javascript\",                          \"dictionaries\": [\"typescript\", \"node\"] },\n    { \"languageId\": \"javascriptreact\",                     \"dictionaries\": [\"typescript\", \"node\"] },\n    { \"languageId\": \"typescript\",                          \"dictionaries\": [\"typescript\", \"node\"] },\n    { \"languageId\": \"typescriptreact\",                     \"dictionaries\": [\"typescript\", \"node\"] },\n    { \"languageId\": \"html\",                                \"dictionaries\": [\"html\", \"fonts\", \"typescript\", \"css\"] },\n    { \"languageId\": \"php\",                                 \"dictionaries\": [\"php\", \"html\", \"fonts\", \"css\", \"typescript\"] },\n    { \"languageId\": \"css\",                                 \"dictionaries\": [\"fonts\", \"css\"] },\n    { \"languageId\": \"less\",                                \"dictionaries\": [\"fonts\", \"css\"] },\n    { \"languageId\": \"scss\",                                \"dictionaries\": [\"fonts\", \"css\"] },\n];\n}\n```\n\n### How to add your own Dictionaries\n\n#### Global Dictionary\n\nTo add a global dictionary, you will need change your user settings.\n\n##### Define the Dictionary\n\nIn your user settings, you will need to tell the spell checker where to find your word list.\n\nExample adding medical terms, so words like *acanthopterygious* can be found.\n\n```javascript\n// A List of Dictionary Definitions.\n\"cSpell.dictionaryDefinitions\": [\n    { \"name\": \"medicalTerms\", \"path\": \"/Users/guest/projects/cSpell-WordLists/dictionaries/medicalterms-en.txt\"}\n],\n// List of dictionaries to use when checking files.\n\"cSpell.dictionaries\": [\n    \"medicalTerms\"\n]\n```\n\n**Explained:** In this example, we have told the spell checker where to find the word list file.\nSince it is in the user settings, we have to use absolute paths.\n\nOnce the dictionary is defined. We need to tell the spell checker when to use it.\nAdding it to `cSpell.dictionaries` advises the spell checker to always include the medical terms when spell checking.\n\n**Note:** Adding large dictionary files to be always used will slow down the generation of suggestions.\n\n#### Project / Workspace Dictionary\n\nTo add a dictionary at the project level, it needs to be in the **cSpell.json** file.\nThis file can be either at the project root or in the .vim directory.\n\nExample adding medical terms, where the terms are checked into the project and we only want to use it for .md files.\n```javascript\n{\n    \"dictionaryDefinitions\": [\n        { \"name\": \"medicalTerms\", \"path\": \"./dictionaries/medicalterms-en.txt\"},\n        { \"name\": \"cities\", \"path\": \"./dictionaries/cities.txt\"}\n    ],\n    \"dictionaries\": [\n        \"cities\"\n    ],\n    \"languageSettings\": [\n        { \"languageId\": \"markdown\", \"dictionaries\": [\"medicalTerms\"] },\n        { \"languageId\": \"plaintext\", \"dictionaries\": [\"medicalTerms\"] }\n    ]\n}\n```\n\n**Explained:** In this example, two dictionaries were defined: *cities* and *medicalTerms*.\nThe paths are relative to the location of the *cSpell.json* file.  This allows for dictionaries to be checked into the project.\n\nThe *cities* dictionary is used for every file type, because it was added to the list to *dictionaries*.\nThe *medicalTerms* dictionary is only used when editing *markdown* or *plaintext* files.\n\n## FAQ\n\nSee: [FAQ](https://github.com/iamcco/coc-spell-checker/blob/master/FAQ.md)\n\n### Buy Me A Coffee ☕️\n\n![btc](https://img.shields.io/keybase/btc/iamcco.svg?style=popout-square)\n\n![image](https://user-images.githubusercontent.com/5492542/42771079-962216b0-8958-11e8-81c0-520363ce1059.png)\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fiamcco%2Fcoc-spell-checker","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fiamcco%2Fcoc-spell-checker","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fiamcco%2Fcoc-spell-checker/lists"}