-
-
Notifications
You must be signed in to change notification settings - Fork 355
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Add spellchecker to CI #1943
Comments
I would like to take a shot with this issue. Does not seem to difficult at all. I look into using the suggested spell checker @brillout |
@IanWorley Ok! So far I think the best would be to integrate the spell check similar to how the formatting check is integrated: https://github.com/vikejs/vike/blob/main/.github/workflows/formatting.yml. |
I will submit a draft pr but I still have some issue at this time for right now I have wrote a config to detect typos from mdx files in the docs directory. Do we want this running on the entire project and what is the scope? Anyway I will also reach out in the discussion of typos as it seems there examples of typos are not being pick up in the mdx file. |
Not for now. (Eventually yes once we don't have any pending open PRs.) For now we can run against the whole
👍 |
To response to this I do not think typos is a npm package. I will look into using cspell at this moment my only problem is that there might be dictionary file if that is fine with you. By the way size of cspell is 203kb |
I found https://github.com/dalisoft/typos-rs-npm so maybe we can use that? We can also ask the typos team if there is an official npm package and if not whether it's on their radar.
How would that be a problem? Can we implement this workflow with it?
That's totally fine. |
Only obvious spelling issuesOne issue of integrating spell checking in the CI is that it isn't clear how to handle false positives: upon a false positive the CI will be red. So we have to tell the spell checker that it's a false positive. I guess some kind of special comment like with Prettier ( So I'm inclined to go with a spell checker that has only few false positives. WorkflowThe reason I was mentioning using an npm package is because it would allow us to correct spelling mistakes by simply running an npm script. That's what we're doing with formatting:
I wonder if we can reproduce the same workflow for spell checking? |
Yeah, at first I was going to use cspell, but the amount of manual dictionary entries seemed tedious at best. That’s why I chose typos-rs-npm instead—it seems far more maintainable than managing a massive custom dictionary with cspell. |
For reference, here's the The config should cover everything within {
"version": "0.2",
"ignorePaths": [
"**/node_modules/**"
],
"dictionaryDefinitions": [],
"dictionaries": [],
"words": [
"36masync",
"36mconst",
"36mexport",
"36mfrom",
"36mfunction",
"36mimport",
"36mreturn",
"aaaaaba",
"AaronBeaudoin",
"Abramov's",
"actiongroup",
"Actix",
"AFAICT",
"aheissenberger",
"Ahrefs",
"alexrabin",
"Alignable",
"antd",
"Aslemammad",
"atrule",
"AurelienLourot",
"automagically",
"bafybeiemxf5abjwjbikoz4mc3a3dla6ual3jsgpdr4cjr3oz3evfyavhwq",
"Bati",
"batijs",
"binedge",
"birkskyum",
"Blankeos",
"brillout",
"brunsten",
"btih",
"Bugsnag",
"build-f7i251e0iwnw",
"build-j95xb988fpln",
"Bulma",
"Burda",
"burdaforward",
"Chakra",
"changeme",
"chokidar",
"chunk-DJBYDrsP",
"cjsx",
"crawlable",
"ctsx",
"cwabehiwqehqwueh",
"cyco130",
"daisyui",
"dataendpointurl",
"demonii",
"disableautorun",
"docpress",
"dotenv",
"ecosia",
"ELIFECYCLE",
"enableeagerstreaming",
"esbuild",
"evenodd",
"fabioricali",
"Fastify",
"favicons",
"flac",
"Flightcontrol",
"FOUC",
"frontmatter",
"gensync",
"getbody",
"getpage",
"gonesurfing",
"hapi",
"hattip",
"hemengke1997",
"homescreens",
"Hono",
"httpresponse",
"IIRC",
"imagetools",
"Immortalin",
"importee",
"importees",
"inlang",
"ipfs",
"ipns",
"jamesladd",
"Jearce",
"jeremypress",
"jfif",
"keepscrollposition",
"Kenzo-Wada",
"KHTML",
"Laravel",
"lewis-fidlers",
"libvpx",
"libx",
"liefern",
"llqijrlvr",
"lolipop",
"lourot",
"luisfloat",
"Macbook",
"magne4000",
"mantine",
"marko",
"mdast",
"mdxeditor",
"metafile",
"mikew",
"minifiers",
"mjsx",
"modulepreload",
"msvideo",
"mtsx",
"navigations",
"nextauth",
"nextjs",
"nextui",
"nitedani",
"nitedani's",
"noexternal",
"nojekyll",
"Nprogress",
"Nuxt",
"onbeforeprerender",
"onbeforerender",
"onbeforeroute",
"onclick",
"onwarn",
"openbittorrent",
"opentrackr",
"opral",
"osseonews",
"outro",
"pagecontext",
"pdanpdan",
"phiberber",
"phonzammi",
"pinia",
"Pixelatex",
"pjpeg",
"popstate",
"Preact",
"prerender",
"prerendered",
"primereact",
"Prio",
"pullstate",
"quicktime",
"quotepath",
"Readables",
"redirections",
"renderpage",
"Rollbar",
"rollup",
"royalswe",
"ryanweal",
"scaffolder",
"shadcn",
"signup",
"solidjs",
"sourcegraph",
"stamppipe",
"Strydom",
"styleregistry",
"stylesheet",
"suppor",
"Symfony",
"tabspace",
"tanstack",
"tauri",
"telefunc",
"ThimoDEV",
"transpiles",
"transpiling",
"trpc",
"typesafe",
"ultimateshadsform",
"unpic",
"unplugin",
"untab",
"Unternehmen",
"urql",
"useclientrouter",
"useconfig",
"usedata",
"usepagecontext",
"USEPOLLING",
"vchirikov",
"Vercel",
"veryslow",
"vike",
"vike-react-antd",
"vikejs",
"Vilay",
"vite",
"vitejs",
"vuetify",
"vueuse",
"Vuex",
"Weltall",
"wobsoriano",
"yuva",
"Zustand"
],
"ignoreWords": [],
"import": [],
"enabled": true
} |
@brillout What's your IDE of choice? It would probably make sense to use something in CI whose dictionaries/ignore comments/etc. are compatible with the IDE plugin. |
Based on the spelling errors I have seen in the source code, I don't now if a non contextual word-only spelling correction would work as intended, because it's not always the most similar "correct" word that was intended (which can often only be determined by taking context into account). My recommendation would be an IDE extension to catch & fix errors as they appear, and a CI action as a safety net. |
Maybe I'm wrong but I feel like this would add too many restrictions on what spellchecker we can use. Especially considering that we already have a couple of restrictions.
Yea, the more typos the spellchecker catches the better. But I think we can already catch more than 90% of typos with a dumb spellcheck which I think it's good enough. Having a good workflow is more important, the spellchecker shouldn't be too disruptive for contributors. That would be a no-go. And so far I think having to maintain a whitelist of unknown words is a no-go for that reason. If we can find a very good spellchecker as well as a good workflow, then that'd be great but I ain't sure we'll find something perfect here.
Makes sense. @IanWorley @cr7pt0gr4ph7 Btw. I was thinking one thing we could do is to implement our own npm package with typos-rs-npm as peer dependency. So we can add custom logic (e.g. for implementing |
@IanWorley @brillout Try remove lockfile, node_modules and cache and re-install last version. It should work on Arch Linux (and other linux too). And all credits goes to @crate-ci for typos. I just made |
I will be firing out a pr soon I just had a build fail but that is due to ratelimit with typos so I will rerun the workflow and get this out to you @brillout |
👍 Looking forward to it.
With |
@brillout Both |
Thank you for the prompt response! (FYI this is the workflow we aim for. I can see many other open source tools being interested in that.) |
I think it is achievable, not with all package managers (for |
@dalisoft Have you considered publishing the package to npm? This would make using it a lot easier. |
@epage @szepeviktor Is that something @crate-ci would be up for? That would be quite convenient, see rationale here. |
We publish source and pre-built binaries to PyPI for easy integration with pre-commit. I'm not for abusing different package systems as a general distribution mechanism but your use case is more like a one-off pre-commit, so I'm open to it. I am unfamiliar with the npm ecosystem so I'm unlikely to set it up myself but if someone wants to contribute what is needed and tell my what account setup is needed, I'll take it. Without knowing more, my main requirement is it fits within our automated release process. |
@brillout Sorry for late reply and thanks again to interest. But i don't want publish to |
Description
Maybe we an use the tool that was used at #1835; IIRC the tool has an npm package.
The text was updated successfully, but these errors were encountered: