tui-syntax-highlight 0.1.0

A syntax highlighter for Ratatui apps
Documentation
# tui-syntax-highlight

[![crates.io](https://img.shields.io/crates/v/tui-syntax-highlight.svg?logo=rust)](https://crates.io/crates/tui-syntax-highlight)
[![docs.rs](https://img.shields.io/docsrs/tui-syntax-highlight?logo=rust)](https://docs.rs/tui-syntax-highlight)
![license](https://img.shields.io/badge/License-MIT%20or%20Apache%202-green.svg)
[![CI](https://github.com/aschey/tui-syntax-highlight/actions/workflows/ci.yml/badge.svg)](https://github.com/aschey/tui-syntax-highlight/actions/workflows/ci.yml)
[![codecov](https://codecov.io/gh/aschey/tui-syntax-highlight/graph/badge.svg?token=ytNY7qPY2x)](https://codecov.io/gh/aschey/tui-syntax-highlight)
![GitHub repo size](https://img.shields.io/github/repo-size/aschey/tui-syntax-highlight)
![Lines of Code](https://aschey.tech/tokei/github/aschey/tui-syntax-highlight)

A library for creating code blocks in
[`ratatui`](https://github.com/ratatui/ratatui) apps with
[`syntect`](https://github.com/trishume/syntect).

![screenshot](https://github.com/aschey/tui-syntax-highlight/blob/main/assets/screenshot.png?raw=true)

## Feature Flags

**Note: One of `regex-onig` or `regex-fancy` is required or `syntect` will not
compile.**

- `regex-onig` - Uses the `onig` regex engine (enabled by default). See
  [syntect's documentation]https://crates.io/crates/syntect for more info.

- `regex-fancy` - Uses the `fancy-regex` regex engine. See
  [syntect's documentation]https://crates.io/crates/syntect for more info.

- `tui-syntax-highlight` - Enables integration with
  [`tui-syntax-highlight`]https://crates.io/crates/tui-syntax-highlight to detect the
  terminal's color support level and automatically use compatible colors.

## Usage

Use `Highlighter` to return a Ratatui `Text` object containing the highlighted
content.

### Highlighting a File

```rust
use std::error::Error;
use std::fs::File;
use syntect::highlighting::ThemeSet;
use syntect::parsing::SyntaxSet;
use tui_syntax_highlight::Highlighter;

fn syntax_highlight() -> Result<(), Box<dyn Error>> {
    let syntax_set = SyntaxSet::load_defaults_newlines();
    let theme_set = ThemeSet::load_defaults();
    let theme = theme_set.themes["base16-ocean.dark"].clone();

    let syntax = syntax_set.find_syntax_by_name("Rust").unwrap();
    let highlighter = Highlighter::new(theme);

    let highlighted_text = highlighter.highlight_reader(
        File::open("./examples/sqlite_custom/build.rs")?,
        syntax,
        &syntax_set,
    )?;

    Ok(())
}
```

### Highlighting Text

```rust
use std::error::Error;
use std::fs::File;
use syntect::highlighting::ThemeSet;
use syntect::parsing::SyntaxSet;
use syntect::util::LinesWithEndings;
use tui_syntax_highlight::Highlighter;

fn syntax_highlight() -> Result<(), Box<dyn Error>> {
    let syntax_set = SyntaxSet::load_defaults_newlines();
    let theme_set = ThemeSet::load_defaults();
    let theme = theme_set.themes["base16-ocean.dark"].clone();

    let syntax = syntax_set.find_syntax_by_name("SQL").unwrap();
    let highlighter = Highlighter::new(theme);

    let highlighted_text = highlighter.highlight_lines(
        LinesWithEndings::from("select a,b,c from table;\nselect b,c,d from table2;"),
        syntax,
        &syntax_set,
    )?;

    Ok(())
}
```

## Additional Themes

The [`syntect-assets`](https://crates.io/crates/syntect-assets) crate provides
additional themes and syntaxes that are compatible with `syntect`. It contains a
few themes like `ansi`, `base16`, and `base16-256` that encodes colors in a
special way - these special encodings are handled automatically by this crate.

## Custom Themes and Syntaxes

Custom themes and syntaxes can be compiled and embedded in the binary. See the
[`sqlite_custom`](https://github.com/aschey/tui-syntax-highlight/tree/main/examples/sqlite_custom)
example for usage.

## Code Block Style

Settings such as the background color, formatting, and line number style can all
be changed. See the available methods in
[`Highlighter`](https://docs.rs/tui_syntax_highlight/struct.Highlighter.html)
for details.

## Supported Rust Versions

The MSRV is currently 1.88.0. Since Cargo's V3 resolver supports MSRV-aware
dependencies, we do not treat an MSRV bump as a breaking change.