- Rewrite README.md with comprehensive documentation covering all features: compression engines, meta plugins, filter plugins, server mode, MCP integration, and configuration - Add MIT LICENSE file - Delete README.org (consolidated into README.md) - Delete empty PLAN.md - Update AGENTS.md with current build/test commands and conventions Co-Authored-By: andrew/openrouter/hunter-alpha <noreply@opencode.ai>
1.8 KiB
1.8 KiB
Agent Configuration
IMPORTANT: xxx | keep | zzz must be as performant as possible in all situations.
Build/Test Commands
IMPORTANT: Do not run the application, start the web server, or the trunk server.
IMPORTANT: Cargo commands cannot be run in parallel. Prefix all commands with TERM=dumb.
TERM=dumb cargo check # Fast compile check
TERM=dumb cargo build # Build project
TERM=dumb cargo test # Run all tests
TERM=dumb cargo test test_name # Run specific test by name substring
TERM=dumb cargo test -- --nocapture # Verbose test output
TERM=dumb cargo fmt --check # Check formatting
TERM=dumb cargo fmt # Apply formatting
TERM=dumb cargo clippy -- -D warnings # Lint (warnings are errors)
TERM=dumb cargo build --release # Release build
TERM=dumb cargo build --features server # With server feature
Code Conventions
anyhow::Resultfor error handling;thiserrorfor custom error types (src/services/error.rs)- Plugin traits:
CompressionEngine,FilterPlugin,MetaPlugin - Dynamic trait objects use
clone_box()forCloneonBox<dyn Trait> - Plugin registration uses
ctorconstructors at module load time - Filter plugins must implement
filter(),clone_box(), andoptions() - Meta plugins extend
BaseMetaPluginfor boilerplate reduction - Enum string representations:
#[strum(serialize_all = "snake_case")] - Lint rules:
deny(clippy::all),deny(unsafe_code)(exceptlibc::umaskin main.rs) - Feature flags:
default = ["magic", "lz4", "gzip"]; optional:server,mcp,swagger
Testing
- Tests in
src/tests/mirroringsrc/structure; shared helpers insrc/tests/common/test_helpers.rs - Key helpers:
create_temp_dir(),create_temp_db(),test_compression_engine() - Test naming:
test_<feature>_<scenario>