25 releases

0.11.5 Dec 9, 2024
0.11.4 Jun 15, 2024
0.11.2 Apr 27, 2024
0.11.1 Mar 21, 2024
0.1.0 May 22, 2018

#10 in Programming languages

Download history 83339/week @ 2024-12-21 88875/week @ 2024-12-28 122879/week @ 2025-01-04 131910/week @ 2025-01-11 125033/week @ 2025-01-18 124219/week @ 2025-01-25 134664/week @ 2025-02-01 140761/week @ 2025-02-08 129850/week @ 2025-02-15 145222/week @ 2025-02-22 126608/week @ 2025-03-01 139735/week @ 2025-03-08 129982/week @ 2025-03-15 128549/week @ 2025-03-22 140607/week @ 2025-03-29 145580/week @ 2025-04-05

566,787 downloads per month
Used in 315 crates (70 directly)

MIT/Apache

97KB
2K SLoC

A library for formatting of text or programming code snippets.

It's primary purpose is to build an ASCII-graphical representation of the snippet with annotations.

Example

The crate uses a three stage process with two conversions between states:

Message --> Renderer --> impl Display

The input type - [Message] is a structure designed to align with likely output from any parser whose code snippet is to be annotated.

The middle structure - [Renderer] is a structure designed to convert a snippet into an internal structure that is designed to store the snippet data in a way that is easy to format. [Renderer] also handles the user-configurable formatting options, such as color, or margins.

Finally, impl Display into a final String output.

features

  • testing-colors - Makes Renderer::styled colors OS independent, which allows for easier testing when testing colored output. It should be added as a feature in [dev-dependencies], which can be done with the following command:
cargo add annotate-snippets --dev --feature testing-colors

annotate-snippets

annotate-snippets is a Rust library for annotation of programming code slices.

crates.io documentation build status

The library helps visualize meta information annotating source code slices. It takes a data structure called Snippet on the input and produces a String which may look like this:

Screenshot

Local Development

cargo build
cargo test

When submitting a PR please use cargo fmt (nightly).

Dependencies

~1.5MB
~24K SLoC