Runtime Mix.Task - set long task description?

I have a Mix.Task I am writing. This is a generic Task runner task, where what it does depends entirely on the project configuration. As such I want running mix help check to use a runtime set long task description.

With a configuration like this:

def project do [ #... checks: [ {"test", "mix", ~W"test --force --warnings-as-errors"}, {"cspell", "npx", ~W"--package=cspell@8.16.0 --yes -- cspell ."}, {"compile (no warnings)", "mix", ~W"compile --force --warnings-as-errors"}, ] #... ] #... 

I want to show this as the help

Runs the following checks: - test - cspell - compile (no warnings) 

I expect doing this would require getting Mix.Task.moduledoc changed to optionally call a callback on the task?

Alternatively if anyone knows of a better way to do what I am doing I am all ears. I believe I can not use an alias, both because I want to call external commands, and because I want to e.g. run test in the test enironment, then compile in the dev environment.

I think you can probably do this with Mix.Project.config/0. Something like:

defmodule Mix.Tasks.CheckHelper do def build_help do checks = Mix.Project.config() |> Keyword.get(:checks) |> Enum.map(fn el -> elem(el, 0) end) |> Enum.join("\n\n") {0, checks} end end 
defmodule Mix.Tasks.Check do use Mix.Task alias Mix.Tasks.CheckHelper Module.put_attribute(__MODULE__, :moduledoc, CheckHelper.build_help()) @impl Mix.Task def run(_args) do Mix.shell().info("use `mix help check`") end end 
$ mix check && mix help check mix check test cspell compile (no warnings) 

I don’t think this is ideal, but it’s a starting point, hopefully. Or it’s bad enough that someone will correct it for an actual solution.