ask_llm 2.1.0

make a request to whatever llm is the best these days, without hardcoding model/provider
Documentation

ask_llm

Minimum Supported Rust Version Lines Of Code

Layer for llm requests, generic over models and providers

Usage

Lib

Provides 2 simple primitives:

oneshot and conversation functions, which follow standard logic for llm interactions, that most providers share.

Then the model is automatically chosen based on whether we care about cost/speed/quality. Currently this is expressed by choosing Model::{Fast/Medium/Slow}, from which we pick a model as hardcoded in current implementation.

When used as a lib, import with

ask_llm = { version = "*", default-features = false }

as clap would be brought otherwise, as it is necessary for cli part to function.

Cli

Wraps the lib with clap. Uses oneshot by default, if needing conversation - read/write it from/to json files.

Semver

Note that due to specifics of implementation, minor version bumps can change effective behavior by changing what model processes the request. Only boundary API changes will be marked with major versions.

License