revue 2.71.1

A Vue-style TUI framework for Rust with CSS styling
Documentation
//! Syntax highlighting for text widgets
//!
//! Provides simple character-based syntax highlighting for common programming languages.
//! For more advanced highlighting, consider integrating with syntect or tree-sitter.

mod css;
mod go;
mod html;
mod javascript;
mod json;
pub mod keywords;
mod markdown;
mod python;
mod rust;
mod shell;
mod sql;
mod toml;
mod types;
mod yaml;

pub use types::{HighlightSpan, Language, SyntaxTheme};

mod highlighter;

pub use highlighter::SyntaxHighlighter;

// KEEP HERE - Tests access internal spans data structure (spans vector and its fields like italic)
#[cfg(test)]
mod tests {
    //! Tests for syntax highlighting

    use crate::widget::syntax::types::{Language, SyntaxTheme};
    use crate::widget::syntax::SyntaxHighlighter;

    #[test]
    fn test_language_detection() {
        assert_eq!(Language::from_extension("rs"), Language::Rust);
        assert_eq!(Language::from_extension("py"), Language::Python);
        assert_eq!(Language::from_extension("js"), Language::JavaScript);
        assert_eq!(Language::from_extension("json"), Language::Json);
        assert_eq!(Language::from_extension("unknown"), Language::None);
    }

    #[test]
    fn test_rust_highlighting() {
        let hl = SyntaxHighlighter::new(Language::Rust);
        let spans = hl.highlight_line("fn main() {");
        assert!(!spans.is_empty());
    }

    #[test]
    fn test_rust_comment_highlighting() {
        let hl = SyntaxHighlighter::new(Language::Rust);
        let spans = hl.highlight_line("// This is a comment");
        assert_eq!(spans.len(), 1);
        assert!(spans[0].italic);
    }

    #[test]
    fn test_rust_string_highlighting() {
        let hl = SyntaxHighlighter::new(Language::Rust);
        let spans = hl.highlight_line("let s = \"hello\";");
        assert!(!spans.is_empty());
    }

    #[test]
    fn test_python_highlighting() {
        let hl = SyntaxHighlighter::new(Language::Python);
        let spans = hl.highlight_line("def hello():");
        assert!(!spans.is_empty());
    }

    #[test]
    fn test_json_highlighting() {
        let hl = SyntaxHighlighter::new(Language::Json);
        let spans = hl.highlight_line("{\"key\": \"value\"}");
        assert!(!spans.is_empty());
    }

    #[test]
    fn test_no_highlighting() {
        let hl = SyntaxHighlighter::new(Language::None);
        let spans = hl.highlight_line("fn main() {}");
        assert!(spans.is_empty());
    }

    #[test]
    fn test_syntax_theme() {
        let dark = SyntaxTheme::dark();
        let light = SyntaxTheme::light();
        let monokai = SyntaxTheme::monokai();

        // Just check they're different
        assert_ne!(dark.keyword.r, light.keyword.r);
        assert_ne!(dark.keyword.r, monokai.keyword.r);
    }
}