Skip to main content

oak_markdown/
lib.rs

1#![doc = include_str!("readme.md")]
2#![feature(new_range_api)]
3#![allow(missing_docs)]
4#![allow(missing_copy_implementations)]
5#![doc(html_logo_url = "https://raw.githubusercontent.com/ygg-lang/oaks/refs/heads/dev/documents/logo.svg")]
6#![doc(html_favicon_url = "https://raw.githubusercontent.com/ygg-lang/oaks/refs/heads/dev/documents/logo.svg")]
7//! Markdown support for the Oak language framework.
8
9/// The Markdown language implementation for Oaks.
10pub mod language;
11
12/// Abstract Syntax Tree for Markdown.
13pub mod ast;
14/// Builder for constructing Markdown syntax trees.
15pub mod builder;
16
17/// Syntax kinds for Markdown.
18/// Lexer for tokenizing Markdown source.
19pub mod lexer;
20/// Language Server Protocol support for Markdown.
21#[cfg(any(feature = "lsp", feature = "oak-highlight", feature = "oak-pretty-print"))]
22pub mod lsp;
23/// MCP module.
24#[cfg(feature = "mcp")]
25pub mod mcp;
26
27/// Parser for building Markdown syntax trees.
28pub mod parser;
29
30pub use crate::{ast::MarkdownRoot, builder::MarkdownBuilder, language::MarkdownLanguage, lexer::MarkdownLexer, parser::MarkdownParser};
31
32#[cfg(feature = "oak-highlight")]
33pub use crate::lsp::highlighter::MarkdownHighlighter;
34
35// #[cfg(feature = "mcp")]
36// pub use crate::mcp::serve_markdown_mcp;
37pub use lexer::token_type::MarkdownTokenType;
38pub use parser::element_type::MarkdownElementType;