//! Lexing, bridging to parser (which does the actual parsing) and //! incremental reparsing. mod text_tree_sink; mod reparsing; use crate::{ parsing::text_tree_sink::build_tree, syntax_node::GreenNode, AstNode, SyntaxError, SyntaxNode, }; pub(crate) use crate::parsing::reparsing::incremental_reparse; pub(crate) fn parse_text(text: &str) -> (GreenNode, Vec) { let lexed = parser::LexedStr::new(text); let parser_tokens = lexed.to_tokens(); let tree_traversal = parser::parse_source_file(&parser_tokens); let (node, errors, _eof) = build_tree(lexed, tree_traversal, false); (node, errors) } /// Returns `text` parsed as a `T` provided there are no parse errors. pub(crate) fn parse_text_as( text: &str, entry_point: parser::ParserEntryPoint, ) -> Result { let lexed = parser::LexedStr::new(text); if lexed.errors().next().is_some() { return Err(()); } let parser_tokens = lexed.to_tokens(); let tree_traversal = parser::parse(&parser_tokens, entry_point); let (node, errors, eof) = build_tree(lexed, tree_traversal, true); if !errors.is_empty() || !eof { return Err(()); } SyntaxNode::new_root(node).first_child().and_then(T::cast).ok_or(()) }