#documentation #ai #language #extract #coding #public-api #symbols

bin+lib daipendency

Provides AI coding assistants with public API from dependencies

9 stable releases

1.2.5 Feb 5, 2025
1.2.4 Jan 31, 2025
1.2.2 Jan 30, 2025
1.1.0 Jan 30, 2025
1.0.1 Jan 22, 2025

#229 in Machine learning

Download history 242/week @ 2025-01-20 684/week @ 2025-01-27 253/week @ 2025-02-03 5/week @ 2025-02-10

958 downloads per month

MIT license

38KB
856 lines

Daipendency

Daipendency extracts narrative and API documentation from a library and outputs it in an LLM-friendly format. This specific project allows you to use the functionality programmatically or via the CLI, so if you just want to integrate it into your favourite AI coding agent, check out daipendency-mcp.

Features

  • Outputs public symbols (e.g. functions) only.
  • Outputs function signatures and documentation, but not the implementation.
  • Only supports Rust for now, but any language supported by tree-sitter can be supported.
  • Reads the source code directly, so it doesn't process the HTML of the generated documentation, thus keeping the output clean.

CLI Usage

daipendency extract-dep: Extract the documentation of a dependency

To extract the documentation of a dependency of the project in the current directory, pass the name of the dependency. For example:

daipendency extract-dep thiserror

Alternatively, you can specify the path to the project that contains the dependency with the --dependant option. For example:

daipendency extract-dep --dependant=/path/to/your/crate thiserror

This command will honour the version of the dependency specified in the manifest file, like Cargo.toml in the case of a Rust crate.

daipendency extract: Extract the documentation of a library

To extract the documentation from a library, pass the path to it. For example:

daipendency extract /path/to/library

Library Usage

You can use the daipendency crate in your own Rust project.

Firstly, you need to load the library from which you want to extract the documentation using Library::load_dependency or Library::load. For example:

use daipendency::{Library, Language};
use std::path::Path;

let library = Library::load_dependency(
    "thiserror",
    Path::new("/path/to/crate"),
    Some(Language::Rust),
)?;

Library instances contain all the symbols (e.g. functions) in the library, grouped into namespaces (e.g. Rust modules, Java packages). You can extract the namespaces and symbols in which you're interested and process them however you want, or you can use the generate_markdown_documentation function to generate a Markdown file as follows:

use daipendency::generate_markdown_documentation;

let documentation = generate_markdown_documentation(&library);

Automatic Language Detection

Daipendency can automatically detect the language of a library if you don't specify it in the CLI with the --language option or in the Library function. However, you should try to specify the language explicitly, since auto-detection can get slow as we add more languages.

Development

Adding Support for a New Language

To add support for a new language, you need to:

  1. Implement the daipendency_extractor::Extractor trait for the language. See daipendency-extractor-rust for an example.
  2. Release your crate. Note that only MIT- or Apache-2.0-licensed crates are eligible for inclusion in Daipendency.
  3. Integrate your crate in src/languages.rs.

Dependencies

~11–20MB
~368K SLoC