mirror of
https://github.com/crate-ci/typos.git
synced 2024-11-21 16:41:01 -05:00
parent
af1324fa37
commit
4b812e1b96
4 changed files with 55 additions and 57 deletions
31
README.md
31
README.md
|
@ -2,28 +2,37 @@
|
||||||
|
|
||||||
> **Source code spell checker**
|
> **Source code spell checker**
|
||||||
|
|
||||||
|
Finds and corrects spelling mistakes among source code:
|
||||||
|
- Fast enough to run on monorepos
|
||||||
|
- Low false positives so you can run on PRs
|
||||||
|
|
||||||
[![Build Status](https://dev.azure.com/crate-ci/crate-ci/_apis/build/status/typos?branchName=master)](https://dev.azure.com/crate-ci/crate-ci/_build/latest?definitionId=11&branchName=master)
|
[![Build Status](https://dev.azure.com/crate-ci/crate-ci/_apis/build/status/typos?branchName=master)](https://dev.azure.com/crate-ci/crate-ci/_build/latest?definitionId=11&branchName=master)
|
||||||
[![codecov](https://codecov.io/gh/crate-ci/typos/branch/master/graph/badge.svg)](https://codecov.io/gh/crate-ci/typos)
|
[![codecov](https://codecov.io/gh/crate-ci/typos/branch/master/graph/badge.svg)](https://codecov.io/gh/crate-ci/typos)
|
||||||
[![Documentation](https://img.shields.io/badge/docs-master-blue.svg)][Documentation]
|
[![Documentation](https://img.shields.io/badge/docs-master-blue.svg)][Documentation]
|
||||||
![License](https://img.shields.io/crates/l/typos.svg)
|
![License](https://img.shields.io/crates/l/typos.svg)
|
||||||
[![Crates Status](https://img.shields.io/crates/v/typos.svg)](https://crates.io/crates/typos)
|
[![Crates Status](https://img.shields.io/crates/v/typos.svg)](https://crates.io/crates/typos)
|
||||||
|
|
||||||
## [About](docs/about.md)
|
Dual-licensed under [MIT](LICENSE-MIT) or [Apache 2.0](LICENSE-APACHE)
|
||||||
|
|
||||||
## [Install](docs/install.md)
|
## Documentation
|
||||||
|
|
||||||
## [Reference](docs/reference.md)
|
- [Installation](#install)
|
||||||
|
- [Reference](docs/reference.md)
|
||||||
|
- [Comparison with other spell checkers](docs/comparison.md)
|
||||||
|
- [Benchmarks](benchsuite/runs)
|
||||||
|
- [Design](docs/design.md)
|
||||||
|
- [Contribute](CONTRIBUTING.md)
|
||||||
|
- [CHANGELOG](CHANGELOG.md)
|
||||||
|
|
||||||
## [Contribute](CONTRIBUTING.md)
|
## Install
|
||||||
|
|
||||||
## License
|
[Download](https://github.com/crate-ci/typos/releases) a pre-built binary
|
||||||
|
(installable via [gh-install](https://github.com/crate-ci/gh-install).
|
||||||
|
|
||||||
Licensed under either of
|
Or use rust to install:
|
||||||
|
```bash
|
||||||
* Apache License, Version 2.0, ([LICENSE-APACHE](LICENSE-APACHE) or http://www.apache.org/licenses/LICENSE-2.0)
|
cargo install typos-cli
|
||||||
* MIT license ([LICENSE-MIT](LICENSE-MIT) or http://opensource.org/licenses/MIT)
|
```
|
||||||
|
|
||||||
at your option.
|
|
||||||
|
|
||||||
[Crates.io]: https://crates.io/crates/typos-cli
|
[Crates.io]: https://crates.io/crates/typos-cli
|
||||||
[Documentation]: https://docs.rs/typos
|
[Documentation]: https://docs.rs/typos
|
||||||
|
|
|
@ -1,38 +1,4 @@
|
||||||
# About `typos`
|
# Related Spell Checkers
|
||||||
|
|
||||||
## Design Requirements
|
|
||||||
|
|
||||||
Spell checks source code:
|
|
||||||
- Requires special word-splitting logic to handle situations like hex (`0xDEADBEEF`), `c\nescapes`, `snake_case`, `CamelCase`, `SCREAMING_CASE`, and maybe `arrow-case`.
|
|
||||||
- Each programming language has its own quirks, like abbreviations, lack of word separator (`copysign`), etc
|
|
||||||
- Backwards compatibility might require keeping misspelled words.
|
|
||||||
- Case for proper nouns is irrelevant.
|
|
||||||
|
|
||||||
Checking for errors in a CI:
|
|
||||||
- No false-positives.
|
|
||||||
- On spelling errors, sets the exit code to fail the CI.
|
|
||||||
|
|
||||||
Quick feedback and resolution for developer:
|
|
||||||
- Fix errors for the user.
|
|
||||||
- Integration into other programs, like editors:
|
|
||||||
- `fork`: easy to call into and provides a stable API, including output format
|
|
||||||
- linking: either in the language of choice or bindings can be made to language of choice.
|
|
||||||
|
|
||||||
## Design Trade Offs
|
|
||||||
|
|
||||||
### typos uses a blacklist
|
|
||||||
|
|
||||||
Blacklist: Known typos that map to their corresponding word
|
|
||||||
- Ignores unknown typos
|
|
||||||
- Ignores typos that follow c-escapes if they aren't handled correctly
|
|
||||||
|
|
||||||
Whitelist: A confidence rating is given for how close a word is to one in the whitelist
|
|
||||||
- Sensitive to false positives due to hex numbers and c-escapes
|
|
||||||
- Traditional spell checkers use a whitelist.
|
|
||||||
|
|
||||||
## Related Spell Checkers
|
|
||||||
|
|
||||||
See also [benchmarks](../benchsuite/runs).
|
|
||||||
|
|
||||||
| | typos | [bloom42/misspell][misspell-rs] | [client9/misspell][misspell-go] | [codespell] | [scspell3k] |
|
| | typos | [bloom42/misspell][misspell-rs] | [client9/misspell][misspell-go] | [codespell] | [scspell3k] |
|
||||||
|----------------|-----------------------|---------------------------------|---------------------------------|-------------|-------------|
|
|----------------|-----------------------|---------------------------------|---------------------------------|-------------|-------------|
|
||||||
|
@ -53,6 +19,8 @@ See also [benchmarks](../benchsuite/runs).
|
||||||
| API | Rust / [JSON Lines] | Rust | ? | Python | None |
|
| API | Rust / [JSON Lines] | Rust | ? | Python | None |
|
||||||
| License | MIT or Apache | AGPL | MIT | GPLv2 | GPLv2 |
|
| License | MIT or Apache | AGPL | MIT | GPLv2 | GPLv2 |
|
||||||
|
|
||||||
|
See also [benchmarks](../benchsuite/runs).
|
||||||
|
|
||||||
[JSON Lines]: http://jsonlines.org/
|
[JSON Lines]: http://jsonlines.org/
|
||||||
[scspell3k]: https://github.com/myint/scspell
|
[scspell3k]: https://github.com/myint/scspell
|
||||||
[misspell-rs]: https://gitlab.com/bloom42/misspell
|
[misspell-rs]: https://gitlab.com/bloom42/misspell
|
32
docs/design.md
Normal file
32
docs/design.md
Normal file
|
@ -0,0 +1,32 @@
|
||||||
|
# Design
|
||||||
|
|
||||||
|
## Requirements
|
||||||
|
|
||||||
|
Spell checks source code:
|
||||||
|
- Requires special word-splitting logic to handle situations like hex (`0xDEADBEEF`), `c\nescapes`, `snake_case`, `CamelCase`, `SCREAMING_CASE`, and maybe `arrow-case`.
|
||||||
|
- Each programming language has its own quirks, like abbreviations, lack of word separator (`copysign`), etc
|
||||||
|
- Backwards compatibility might require keeping misspelled words.
|
||||||
|
- Case for proper nouns is irrelevant.
|
||||||
|
|
||||||
|
Checking for errors in a CI:
|
||||||
|
- No false-positives.
|
||||||
|
- On spelling errors, sets the exit code to fail the CI.
|
||||||
|
|
||||||
|
Quick feedback and resolution for developer:
|
||||||
|
- Fix errors for the user.
|
||||||
|
- Integration into other programs, like editors:
|
||||||
|
- `fork`: easy to call into and provides a stable API, including output format
|
||||||
|
- linking: either in the language of choice or bindings can be made to language of choice.
|
||||||
|
|
||||||
|
## Trade Offs
|
||||||
|
|
||||||
|
### typos uses a blacklist
|
||||||
|
|
||||||
|
Blacklist: Known typos that map to their corresponding word
|
||||||
|
- Ignores unknown typos
|
||||||
|
- Ignores typos that follow c-escapes if they aren't handled correctly
|
||||||
|
|
||||||
|
Whitelist: A confidence rating is given for how close a word is to one in the whitelist
|
||||||
|
- Sensitive to false positives due to hex numbers and c-escapes
|
||||||
|
- Traditional spell checkers use a whitelist.
|
||||||
|
|
|
@ -1,11 +0,0 @@
|
||||||
# Install
|
|
||||||
|
|
||||||
|
|
||||||
[Download](https://github.com/crate-ci/typos/releases) a pre-built binary
|
|
||||||
(installable via [gh-install](https://github.com/crate-ci/gh-install).
|
|
||||||
|
|
||||||
Or use rust to install:
|
|
||||||
```bash
|
|
||||||
cargo install typos-cli
|
|
||||||
```
|
|
||||||
|
|
Loading…
Reference in a new issue