| Crates.io | oak-json |
| lib.rs | oak-json |
| version | 0.0.1 |
| created_at | 2025-10-21 08:58:32.703349+00 |
| updated_at | 2026-01-23 04:30:30.681664+00 |
| description | High-performance incremental JSON parser for the oak ecosystem with flexible configuration, optimized for data interchange and configuration files. |
| homepage | https://github.com/ygg-lang/oaks |
| repository | https://github.com/ygg-lang/oaks |
| max_upload_size | |
| id | 1893500 |
| size | 91,213 |
High-performance incremental JSON parser for the oak ecosystem with flexible configuration, optimized for data processing and analysis.
Oak JSON is a robust parser for JSON, designed to handle complete JSON syntax including modern features. Built on the solid foundation of oak-core, it provides both high-level convenience and detailed AST generation for data processing and analysis.
Basic example:
use oak_core::{Parser, SourceText, parser::session::ParseSession};
use oak_json::{JsonParser, JsonLanguage};
fn main() -> Result<(), Box<dyn std::error::Error>> {
let mut session = ParseSession::<JsonLanguage>::default();
let parser = JsonParser::new();
let source = SourceText::new(r#"
{
"name": "Alice",
"age": 30,
"skills": ["Rust", "JavaScript", "Python"]
}
"#);
let result = parser.parse(&source, &[], &mut session);
println!("Parsed JSON successfully.");
Ok(())
}
use oak_core::{Parser, SourceText, parser::session::ParseSession};
use oak_json::{JsonParser, JsonLanguage};
let mut session = ParseSession::<JsonLanguage>::default();
let parser = JsonParser::new();
let source = SourceText::new(r#"{"name": "Alice", "age": 30}"#);
let result = parser.parse(&source, &[], &mut session);
println!("Object parsed successfully.");
use oak_core::{Parser, SourceText, parser::session::ParseSession};
use oak_json::{JsonParser, JsonLanguage};
let mut session = ParseSession::<JsonLanguage>::default();
let parser = JsonParser::new();
let source = SourceText::new(r#"[1, 2, 3, 4, 5]"#);
let result = parser.parse(&source, &[], &mut session);
println!("Array parsed successfully.");
use oak_core::{Parser, SourceText, parser::session::ParseSession};
use oak_json::{JsonParser, JsonLanguage};
let mut session = ParseSession::<JsonLanguage>::default();
let parser = JsonParser::new();
let source = SourceText::new(r#"{"key": "value"}"#);
let result = parser.parse(&source, &[], &mut session);
println!("Token parsing completed.");
use oak_core::{Parser, SourceText, parser::session::ParseSession};
use oak_json::{JsonParser, JsonLanguage};
let mut session = ParseSession::<JsonLanguage>::default();
let parser = JsonParser::new();
let source = SourceText::new(r#"
{
"name": "Alice",
"age": 30,
"skills": ["Rust", "JavaScript", "Python"
// Missing closing brace
"#);
let result = parser.parse(&source, &[], &mut session);
if let Some(errors) = result.result.err() {
println!("Parse errors found: {:?}", errors);
} else {
println!("Parsed successfully.");
}
The parser generates a comprehensive AST with the following main structures:
Oak JSON integrates seamlessly with:
Check out the examples directory for comprehensive examples:
Contributions are welcome!
Please feel free to submit pull requests at the project repository or open issues.