A fast, opinionated, batteries-included toolchain CLI for Haskell.
- Fast feedback loop - Common workflows are snappy with parallel builds
- Deterministic builds - Lockfile + frozen plans for reproducibility
- Native builds - Direct GHC invocation without cabal for simple projects
- Excellent errors - Actionable messages with fix suggestions
- Watch mode - Auto-rebuild on file changes
- Test coverage - Integrated hpc support with HTML reports
- Plugin system - Extensible with Steel (Scheme) scripts
- Self-contained - Manages GHC versions directly, no ghcup required
# macOS/Linux
curl -fsSL https://raw.githubusercontent.com/raskell-io/hx/main/install.sh | sh
# Or download from releases
https://github.com/raskell-io/hx/releasescargo install --git https://github.com/raskell-io/hx hx-clihx --version
hx doctor# Create a new project
hx init --bin --name myapp
cd myapp
# Build and run
hx build
hx run
# Lock dependencies for reproducibility
hx lock
hx sync
# Watch for changes
hx watchhx init # Initialize a new project
hx init --bin # Create an executable project
hx init --lib # Create a library project
hx init --ci # Include GitHub Actions workflow
hx new webapp myapp # Create web app (Servant)
hx new cli myapp # Create CLI app (optparse-applicative)
hx new library mylib # Create library with docs setup
hx new --template user/repo # Create from git templatehx build # Build the project
hx build --release # Build with optimizations
hx build --native # Use native GHC build (no cabal)
hx build -j4 # Parallel build with 4 jobs
hx check # Fast type-check
hx clean # Clean build artifactshx run # Build and run the executable
hx run -- arg1 arg2 # Pass arguments to the program
hx repl # Start an interactive GHCi session
hx test # Run tests
hx test --pattern "Unit" # Filter tests by pattern
hx bench # Run benchmarkshx watch # Auto-rebuild on file changes
hx watch --test # Auto-run tests on changes
hx watch --clear # Clear terminal between runshx lock # Generate/update hx.lock
hx lock --update # Update all dependencies
hx sync # Build with locked dependencies
hx fetch # Pre-fetch dependencies in parallel
hx add text # Add a dependency
hx add --dev hspec # Add dev dependency
hx rm text # Remove a dependency
hx deps tree # Show dependency tree
hx deps graph --format dot # Generate Graphviz graph
hx deps list --direct # List direct dependencies only
hx search aeson # Search Hackage for packages
hx audit # Check for vulnerabilities
hx audit --outdated # Check for outdated packageshx fmt # Format code with fourmolu
hx fmt --check # Check formatting without changes
hx lint # Run hlint
hx lint --fix # Apply automatic fixeshx coverage # Run tests with coverage
hx coverage --html # Generate HTML report
hx coverage --html --open # Generate and open in browser
hx coverage --threshold 80 # Fail if below 80% coverage
hx coverage --json # Output JSON for CIhx profile # Run with time profiling
hx profile --heap # Run with heap profiling
hx profile --time --heap # Both time and heaphx docs # Generate documentation
hx docs --open # Generate and open in browser
hx docs --deps # Include dependency docs
hx docs --serve # Serve locally on port 8080hx toolchain status # Show installed versions
hx toolchain list # List all available versions
hx toolchain list --installed # List installed versions only
hx toolchain install 9.8.2 # Install GHC version
hx toolchain install --set # Install and set as active
hx toolchain remove 9.6.4 # Remove a GHC version
hx toolchain use 9.8.2 # Switch GHC version
hx toolchain use project # Use project's toolchainhx ide setup # Generate hie.yaml for HLS
hx ide status # Check IDE configuration
hx lsp # Start language serverhx publish # Publish to Hackage
hx publish --dry-run # Validate without uploading
hx publish --docs # Include documentation
hx changelog # Generate CHANGELOG from commits
hx changelog --preview # Preview without writinghx dist # Build release archive
hx dist --target x86_64-unknown-linux-musl # Cross-compile
hx dist formula # Generate Homebrew formula
hx dist install-script # Generate install scripthx doctor # Diagnose setup issues
hx script file.hs # Run single-file script
hx import --from stack # Import from stack.yaml
hx nix flake # Generate flake.nix
hx nix shell # Generate shell.nix
hx completions bash # Generate shell completions
hx upgrade # Upgrade hx to latest versionhx cache status # Show cache statistics
hx cache prune --days 30 # Remove entries older than 30 days
hx cache clean # Clear entire cache
hx index update # Update Hackage package index
hx index status # Show index statushx plugins list # List available plugins
hx plugins status # Show plugin system status
hx plugins run script.scm # Run a Steel scripthx uses hx.toml for project configuration:
[project]
name = "myapp"
kind = "bin" # or "lib"
resolver = "cabal"
[toolchain]
ghc = "9.8.2"
cabal = "3.12.1.0"
hls = "2.9.0.0"
[build]
optimization = 2 # 0, 1, or 2
warnings = true
native = false # Use native GHC builds
[format]
formatter = "fourmolu"
[lint]
hlint = true
[plugins]
enabled = true
hook_timeout_ms = 30000
[plugins.hooks]
pre_build = ["./scripts/check.scm"]
post_test = ["./scripts/notify.scm"]The hx.lock file ensures reproducible builds:
version = 1
created_at = "2026-01-16T00:00:00Z"
[toolchain]
ghc = "9.8.2"
cabal = "3.12.1.0"
[plan]
compiler_id = "ghc-9.8.2"
platform = "x86_64-linux"
hash = "sha256:..."
[[packages]]
name = "text"
version = "2.1.1"| Variable | Description |
|---|---|
HX_VERBOSE |
Enable verbose output |
HX_QUIET |
Suppress output |
HX_NO_COLOR |
Disable colored output |
HX_CONFIG_FILE |
Path to config file |
HX_CACHE_DIR |
Cache directory location |
HX_AUTO_INSTALL |
Auto-install missing toolchains |
HX_NO_AUTO_INSTALL |
Never auto-install toolchains |
| Code | Meaning |
|---|---|
| 0 | Success |
| 1 | General error |
| 2 | Usage error |
| 3 | Configuration error |
| 4 | Toolchain error |
| 5 | Build/test failure |
| 6 | Plugin hook failure |
hx is a Rust workspace with these crates:
| Crate | Purpose |
|---|---|
hx-cli |
Command-line interface |
hx-core |
Shared types and utilities |
hx-config |
Configuration parsing |
hx-lock |
Lockfile management |
hx-toolchain |
GHC/Cabal detection and installation |
hx-cabal |
Cabal wrapper and native builds |
hx-cache |
Build cache management |
hx-doctor |
Diagnostic checks |
hx-solver |
Native dependency resolver |
hx-lsp |
Language server protocol |
hx-plugins |
Steel plugin runtime |
hx-ui |
Terminal output utilities |
hx-warnings |
Warning system |
hx-telemetry |
Tracing and metrics |
# Build
cargo build
# Run tests
cargo test --workspace
# Run clippy
cargo clippy --workspace -- -D warnings
# Format
cargo fmt
# Run hx locally
cargo run -p hx-cli -- --helphx follows the Astral approach:
- Wrap first - Use existing tools (Cabal, GHC) rather than reimplementing
- Tame second - Add better UX, error messages, and workflows
- Replace last - Only replace components when truly necessary (native builds)
MIT