cuc-cli

Crates.iocuc-cli
lib.rscuc-cli
version0.2.3
created_at2025-07-22 17:28:22.49768+00
updated_at2025-12-31 00:44:22.473231+00
descriptionA CLI tool to generate clink argmatcher completions from the usage spec.
homepagehttps://github.com/IMXEren/cuc
repositoryhttps://github.com/IMXEren/cuc
max_upload_size
id1763793
size91,023
(IMXEren)

documentation

README

cuc (Clink Usage Completions)

A CLI tool to generate clink argmatcher completions from the usage spec.

Installation

  1. Go to Releases and download the executable to a desired location. You could also use powershell to download

    Invoke-RestMethod "https://github.com/IMXEren/cuc/releases/download/v0.1.0/cuc-v0.1.0-x64.exe" -OutFile "cuc.exe"
    
  2. The generated usage.completions.lua requires that you have these modules in your package.path (you can also use !init.lua or .init.lua, to ensure the modules are added to package.path):

  3. For dynamic completion i.e. a usage.spec.kdl that uses complete, you'd need a shell while generating. The complete node in the spec uses run command that require unix shells. As a workaround, you can use git-bash which would work fine (CLI already uses it). So, you'd need to specify when using shell other than git-bash (or if not found) like MSYS2 environment.

  4. For loading completions, you can either provide the spec from a file or by stdin.

    load(io.popen("abs/path/cuc.exe generate [OPTIONS] abs/path/usage.kdl"):read("*a"))()
    load(io.popen("mycli usage | abs/path/cuc.exe generate [OPTIONS]"):read("*a"))()
    
  5. For an example, you can check out mise-clink.

Unsupported Features

There are some of the features currently unsupported by cuc generated completions, which may be supported by usage completions.

  1. config and it's related properties.
  2. *_help
  3. example
  4. source_code_link_template
  5. version
  6. author
  7. license
  8. about
  9. arg > parse, double_dash
  10. flag > count, env, config, required_*, overrides
  11. cmd > subcommand_required, mount
  12. complete > descriptions
Commit count: 0

cargo fmt