Expand description
A tightly typed Rust interface for the Claude Code JSON protocol
This crate provides type-safe bindings for interacting with the Claude CLI through its JSON Lines protocol. It handles the complexity of message serialization, deserialization, and streaming communication with Claude.
§Quick Start
Add this crate to your project:
cargo add claude-codes§Using the Async Client (Recommended)
use claude_codes::AsyncClient;
#[tokio::main]
async fn main() -> Result<(), Box<dyn std::error::Error>> {
    // Create a client with automatic version checking
    let mut client = AsyncClient::with_defaults().await?;
     
    // Send a query and stream responses
    let mut stream = client.query_stream("What is 2 + 2?").await?;
     
    while let Some(response) = stream.next().await {
        match response {
            Ok(output) => {
                println!("Received: {}", output.message_type());
                // Handle different message types
            }
            Err(e) => eprintln!("Error: {}", e),
        }
    }
     
    Ok(())
}§Using the Sync Client
use claude_codes::{SyncClient, ClaudeInput};
fn main() -> Result<(), Box<dyn std::error::Error>> {
    // Create a synchronous client
    let mut client = SyncClient::with_defaults()?;
     
    // Build a structured input message  
    let input = ClaudeInput::user_message("What is 2 + 2?", uuid::Uuid::new_v4());
     
    // Send and collect all responses
    let responses = client.query(input)?;
     
    for response in responses {
        println!("Received: {}", response.message_type());
    }
     
    Ok(())
}§Architecture
The crate is organized into several key modules:
- [client] - High-level async and sync clients for easy interaction
- protocol- Core JSON Lines protocol implementation
- io- Top-level message types (- ClaudeInput,- ClaudeOutput)
- messages- Detailed message structures for requests and responses
- cli- Builder for configuring Claude CLI invocation
- error- Error types and result aliases
- version- Version compatibility checking
§Version Compatibility
⚠️ Important: The Claude CLI protocol is unstable and evolving. This crate automatically checks your Claude CLI version and warns if it’s newer than tested.
Current tested version: 1.0.89
Report compatibility issues at: https://github.com/meawoppl/rust-claude-codes/pulls
§Message Types
The protocol uses several message types:
- System - Initialization and metadata messages
- User - Input messages from the user
- Assistant - Claude’s responses
- Result - Session completion with timing and cost info
§Examples
See the examples/ directory for complete working examples:
- async_client.rs- Simple async client usage
- sync_client.rs- Synchronous client usage
- basic_repl.rs- Interactive REPL implementation
Re-exports§
- pub use error::Error;
- pub use error::Result;
- pub use io::AssistantMessageContent;
- pub use io::ClaudeInput;
- pub use io::ClaudeOutput;
- pub use io::ParseError;
- pub use protocol::MessageEnvelope;
- pub use protocol::Protocol;
- pub use client_async::AsyncClient;
- pub use client_async::AsyncStreamProcessor;
- pub use client_sync::StreamProcessor;
- pub use client_sync::SyncClient;
- pub use cli::ClaudeCliBuilder;
- pub use cli::PermissionMode;
- pub use messages::*;
- pub use types::*;
Modules§
- cli
- Builder pattern for configuring and launching the Claude CLI process.
- client_async 
- Asynchronous client for Claude communication
- client_sync 
- Synchronous client for Claude communication
- error
- Error types for the Claude Code protocol
- io
- Core message types for Claude communication.
- messages
- Message types for the Claude Code protocol
- protocol
- JSON Lines protocol implementation for Claude communication.
- types
- Core types used in the Claude Code protocol
- version
- Version checking utilities for Claude CLI compatibility