Selective prose linting with Vale’s glob switch

Vale is an open source CLI tool for linting prose (if you’re not linting prose yet, why not? I never want to go back). I typically use it for everything, locally and in CI, and it’s especially valuable now I’m working for a company that uses US English. You’d think that most of the challenges would be caused by the majority of non-native English language contributors? Nope, most of the chaos comes from the token Brit :)

I ran into one challenge though where I didn’t want to enable Vale for everything: a large internal documentation repo. This is the catch-all of things we should share with one another and like most internal company documentation sites, there is a lot going on. I assembled a very minimal set of Vale rules and still the first pass netted me over 10k errors. Luckily, Vale has a --glob option, but it took me a while to find how to exclude multiple files and directories using it, so here’s the example for future-me, and anyone else who needs to see it!

Most of Vale’s configuration uses a .vale.ini file, but you specify the files and directories to check at the time you run the command, with something like:

vale docs/

In my case, I needed to exclude a mix of folders (there’s little value in checking/fixing a meeting notes collection of a past project, and we can’t make changes to our legal docs. Also there’s a page of good restaurants near the office that is full of proper nouns!). To include just one section or another, I could run Vale multiple times to check each section, but to run everything except some problem areas, I used --glob. I ended up with a command like this:

vale --glob='!{office/where-to-eat.md,legal/*,projects/codename/meetings/*}

Some of the skipped directories we will probably work on improving and then dropping the exception for – but this approach is useful when retrofitting a tool like Vale to an existing repository which can’t be made to align all at once. We’re also using a pretty reduced ruleset and may incrementally add to this over time.

Glob in GitHub Actions

Probably all the CI integrations have something similar but Vale has a GitHub Action and I could add the whole --glob expression to a vale_flags entry in the with step.

Ideally we’d be running identical commands and configuration both locally and in CI, but since the configuration for this doesn’t seem to be able to go in the Vale config file, I compromised on adding it as an npm script as well as a GitHub action. It’ll be annoying to maintain but I didn’t come up with any better ideas!

Hopefully this post will help me next time I’m wondering how to combine glob expressions for Vale, since I didn’t find many other examples. If it helps you do, then that’s even better! Share your tips in the comments :)


Also published on Medium.

One thought on “Selective prose linting with Vale’s glob switch

  1. Thanks for this gem! I had hoped that I could use some [code]ignore[/code] value in [code]vale.ini[/code], but that’s not how it works. Thanks to this article, I have a work-around.

    Note that the globs can include `**` to match deeply into directory trees, for example:

    [code]
    vale –glob=’!{seceng/**/*.md,qa/**/*.md}’
    [/code]

Leave a Reply

Please use [code] and [/code] around any source code you wish to share.

This site uses Akismet to reduce spam. Learn how your comment data is processed.