| name | hackage-read-docs |
| description | Retrieve documentation from Hackage. Use this Skill when you need a reference for Haskell packages, classes, or want to query package versions. (project) |
Hackage Read Docs
A CLI tool to query Hackage package documentation with filtering and display options.
Instructions
- use
bazel run //haskell/app/hackage-doc-cli:hackage-doc-cli -- <package_name> --list-versionsto discover what package versions are there - then use
bazel run //haskell/app/hackage-doc-cli:hackage-doc-cli -- <package_name> --version <version>to discover the modules that are in the package
Quick Start
List all available versions
bazel run //haskell/app/hackage-doc-cli:hackage-doc-cli -- aeson --list-versions
Query a specific version (shows tree view)
bazel run //haskell/app/hackage-doc-cli:hackage-doc-cli -- aeson --version 2.2.3.0
Deep dive into a module
bazel run //haskell/app/hackage-doc-cli:hackage-doc-cli -- aeson --module Data.Aeson
Filter Options
Show only specific types of exports:
# Show only functions
bazel run //haskell/app/hackage-doc-cli:hackage-doc-cli -- aeson --module Data.Aeson --filter-functions
# Show only types
bazel run //haskell/app/hackage-doc-cli:hackage-doc-cli -- aeson --module Data.Aeson --filter-types
# Show only type classes
bazel run //haskell/app/hackage-doc-cli:hackage-doc-cli -- aeson --module Data.Aeson --filter-classes
# Combine filters (e.g., show functions and types, exclude classes)
bazel run //haskell/app/hackage-doc-cli:hackage-doc-cli -- aeson --module Data.Aeson --filter-functions --filter-types
Documentation Display
Include Haddock documentation text alongside signatures:
# Show functions with their documentation
bazel run //haskell/app/hackage-doc-cli:hackage-doc-cli -- aeson --module Data.Aeson --filter-functions --with-comments
# Show types with their documentation
bazel run //haskell/app/hackage-doc-cli:hackage-doc-cli -- aeson --module Data.Aeson --filter-types --with-comments
# Show type classes with their documentation
bazel run //haskell/app/hackage-doc-cli:hackage-doc-cli -- aeson --module Data.Aeson --filter-classes --with-comments
Common Patterns
Research a specific function
# Find a function and see its documentation
bazel run //haskell/app/hackage-doc-cli:hackage-doc-cli -- aeson --module Data.Aeson --filter-functions --with-comments | grep -A 3 "decode"
Explore all types in a module
# See all type definitions with documentation
bazel run //haskell/app/hackage-doc-cli:hackage-doc-cli -- containers --module Data.Map --filter-types --with-comments
Find available type classes
# List type classes with their documentation
bazel run //haskell/app/hackage-doc-cli:hackage-doc-cli -- aeson --module Data.Aeson --filter-classes --with-comments
Workflow
Start with version listing: Always list versions first, pick the latest if unclear
bazel run //haskell/app/hackage-doc-cli:hackage-doc-cli -- PACKAGE --list-versionsQuery package tree: View the package structure and available modules
bazel run //haskell/app/hackage-doc-cli:hackage-doc-cli -- PACKAGE --version X.Y.ZExplore specific module: Deep dive into a module with filters as needed
bazel run //haskell/app/hackage-doc-cli:hackage-doc-cli -- PACKAGE --module MODULE.NAMEApply filters: Use
--filter-*flags to focus on specific export typesInclude documentation: Add
--with-commentsto see Haddock documentation
Available Flags
--version, -v VERSION: Query specific package version--list-versions, -l: List all available versions--module, -m MODULE: Query specific module (e.g., Data.Aeson)--filter-functions: Show only exported functions--filter-types: Show only exported types--filter-classes: Show only exported type classes--with-comments: Include Haddock documentation text alongside signatures
Examples
# Research the aeson package's FromJSON class
bazel run //haskell/app/hackage-doc-cli:hackage-doc-cli -- aeson --module Data.Aeson --filter-classes --with-comments | grep -A 10 "FromJSON"
# Find all functions in Data.List
bazel run //haskell/app/hackage-doc-cli:hackage-doc-cli -- base --module Data.List --filter-functions
# Explore container types with documentation
bazel run //haskell/app/hackage-doc-cli:hackage-doc-cli -- containers --module Data.Map --filter-types --with-comments
Notes
- Default behavior (no filters): Shows functions, types, and type classes
- Documentation is extracted from Haddock HTML pages
- Supports both PVP and Semantic Versioning formats
- Results are cached for performance (24h for metadata, 7d for versions)