use llm::{
builder::{LLMBackend, LLMBuilder}, chat::ChatMessage, };
#[tokio::main]
async fn main() -> Result<(), Box<dyn std::error::Error>> {
let api_key = std::env::var("COHERE_API_KEY").unwrap_or("test-key-123".into());
let llm = LLMBuilder::new()
.backend(LLMBackend::Cohere) .api_key(api_key) .model("command-a-03-2025") .system("Answer like a pirate.") .max_tokens(200) .temperature(0.7) .build()
.expect("Failed to build LLM (Cohere)");
let messages = vec![ChatMessage::user().content("What is 2 + 2?").build()];
match llm.chat(&messages).await {
Ok(response) => println!("Cohere model response:\n{response}"),
Err(e) => eprintln!("Error calling Cohere: {e}"),
}
Ok(())
}