annotate-snippets

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

crates.io Build Status Coverage Status

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

text error[E0308]: mismatched types --> src/format.rs:52:1 | 51 | ) -> Option<String> { | -------------- expected `Option<String>` because of return type 52 | / for ann in annotations { 53 | | match (ann.range.0, ann.range.1) { 54 | | (None, None) => continue, 55 | | (Some(start), Some(end)) if start > end_index => continue, ... | 71 | | } 72 | | } | |_____^ expected enum `std::option::Option`, found ()

Documentation

Installation

toml [dependencies] annotate-snippets-rs = "0.0.7"

Usage

```rust extern crate annotate_snippets;

use annotate_snippets::snippet;

fn main() { let snippet = Snippet { title: Some(Annotation { label: Some("expected type, found 22".tostring()), id: None, annotationtype: AnnotationType::Error, }), footer: vec![], slices: vec![ Slice { source: r#" This is an example content of the slice which will be annotated with the list of annotations below. "#.tostring(), linestart: 26, origin: Some("examples/example.txt".tostring()), fold: false, annotations: vec![ SourceAnnotation { label: "Example error annotation".tostring(), annotationtype: AnnotationType::Error, range: (13, 18), }, SourceAnnotation { label: "and here's a warning".tostring(), annotation_type: AnnotationType::Warning, range: (34, 50), }, ], }, ], };

let dl = DisplayList::from(snippet);
let dlf = DisplayListFormatter::new(true);
dlf.format(&dl);

} ```

Local Development

cargo build
cargo test

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