Skip to main content

ParserRegistry

Struct ParserRegistry 

Source
pub struct ParserRegistry { /* private fields */ }
Expand description

Registry of all full-AST parsers, keyed by protocol name.

Provides language detection by file extension and dispatches parse/emit operations to the appropriate language parser.

Implementations§

Source§

impl ParserRegistry

Source

pub fn new() -> Self

Create a new registry populated with all enabled language parsers.

With the grammars feature (default), this populates the registry from panproto-grammars, which provides up to 259 tree-sitter languages. Without the grammars feature, this returns an empty registry; call register to add parsers manually using individual grammar crates.

Source

pub fn register(&mut self, parser: Box<dyn AstParser>)

Register a parser implementation.

Source

pub fn register_external_grammar( &mut self, name: &'static str, extensions: Vec<&'static str>, language: Language, node_types_json: &'static [u8], tags_query: Option<&'static str>, grammar_json: Option<&'static [u8]>, ) -> Result<(), ParseError>

Register a tree-sitter language as a full-AST parser.

Used by panproto-grammars-* companion crates that ship grammars outside the default panproto-grammars build. The byte-slice arguments must outlive this registry; the canonical pattern is for the companion to bake the data into &'static rodata at compile time and pass references that are valid for the process lifetime.

walker_config is looked up by name from the bundled per-language configuration table. Languages without a tailored configuration fall back to the default walker config.

§Errors

Returns ParseError if theory extraction from node_types_json fails or if the tags query rejects compilation.

Source

pub fn register_external_grammar_owned( &mut self, name: String, extensions: Vec<String>, language: Language, node_types_json: Vec<u8>, tags_query: Option<String>, grammar_json: Option<Vec<u8>>, ) -> Result<(), ParseError>

Owned-data variant of register_external_grammar.

Accepts String / Vec<u8> rather than &'static references. The caller is presumed not to have process-lifetime rodata available (typical dev-time use: bytes read from disk via the Python binding’s override hook). To match the trait’s 'static lifetime requirement the inputs are leaked into the heap; the leak is one-time per override.

This is the registration primitive for grammar-author workflows where a grammar’s parser.c / grammar.json / node-types.json are evolving outside the panproto release cadence. Production builds should continue to use register_external_grammar with 'static data baked into the binary at compile time.

§Errors

Returns ParseError if theory extraction or tags-query compilation fails.

Source

pub fn unregister(&mut self, name: &str) -> bool

Remove a registration by protocol name.

Drops the parser and any extension mappings that pointed at it. Returns true if a parser was removed, false if no such registration existed. Primarily intended for grammar-author workflows where a registered grammar is being replaced by a freshly-compiled version mid-process.

Source

pub fn override_grammar( &mut self, name: String, extensions: Vec<String>, language: Language, node_types_json: Vec<u8>, tags_query: Option<String>, grammar_json: Option<Vec<u8>>, ) -> Result<(), ParseError>

Override a registered grammar with new owned data.

Equivalent to unregister followed by register_external_grammar_owned, and intended for the same grammar-author dev workflow. Any extension mappings previously bound to name are replaced by the new extensions.

§Errors

Returns ParseError if theory extraction or tags-query compilation fails on the new grammar; in that case the prior registration is already gone.

Source

pub fn detect_language(&self, path: &Path) -> Option<&str>

Detect the language protocol for a file path by its extension.

Returns None if the extension is not recognized (caller should fall back to the raw_file protocol).

Source

pub fn parse_file( &self, path: &Path, content: &[u8], ) -> Result<Schema, ParseError>

Parse a file by detecting its language from the file path.

§Errors

Returns ParseError::UnknownLanguage if the file extension is not recognized. Returns other ParseError variants if parsing fails.

Source

pub fn parse_with_protocol( &self, protocol: &str, content: &[u8], file_path: &str, ) -> Result<Schema, ParseError>

Parse source code with a specific protocol name.

§Errors

Returns ParseError::UnknownLanguage if the protocol is not registered.

Source

pub fn emit_with_protocol( &self, protocol: &str, schema: &Schema, ) -> Result<Vec<u8>, ParseError>

Emit a schema back to source code bytes using the specified protocol.

§Errors

Returns ParseError::UnknownLanguage if the protocol is not registered.

Source

pub fn emit_pretty_with_protocol( &self, protocol: &str, schema: &Schema, ) -> Result<Vec<u8>, ParseError>

Render a by-construction schema using the named protocol.

§Errors

Returns ParseError::UnknownLanguage if the protocol is not registered, or ParseError::EmitFailed from the underlying parser’s emit_pretty.

Source

pub fn theory_meta(&self, protocol: &str) -> Option<&ExtractedTheoryMeta>

Get the theory metadata for a specific protocol.

Source

pub fn protocol_names(&self) -> impl Iterator<Item = &str>

List all registered protocol names.

Source

pub fn has_parser(&self, protocol: &str) -> bool

O(1) lookup: is a parser already registered for protocol?

Useful for dedup at the registration boundary. The umbrella panproto-grammars-all companion pack overlaps with both the built-in core grammars and every per-group pack; callers can short-circuit before re-registering rather than scanning protocol_names() linearly.

Source

pub fn len(&self) -> usize

Get the number of registered parsers.

Source

pub fn is_empty(&self) -> bool

Check if the registry is empty.

Trait Implementations§

Source§

impl Default for ParserRegistry

Source§

fn default() -> Self

Returns the “default value” for a type. Read more

Auto Trait Implementations§

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<D> OwoColorize for D

Source§

fn fg<C>(&self) -> FgColorDisplay<'_, C, Self>
where C: Color,

Set the foreground color generically Read more
Source§

fn bg<C>(&self) -> BgColorDisplay<'_, C, Self>
where C: Color,

Set the background color generically. Read more
Source§

fn black(&self) -> FgColorDisplay<'_, Black, Self>

Change the foreground color to black
Source§

fn on_black(&self) -> BgColorDisplay<'_, Black, Self>

Change the background color to black
Source§

fn red(&self) -> FgColorDisplay<'_, Red, Self>

Change the foreground color to red
Source§

fn on_red(&self) -> BgColorDisplay<'_, Red, Self>

Change the background color to red
Source§

fn green(&self) -> FgColorDisplay<'_, Green, Self>

Change the foreground color to green
Source§

fn on_green(&self) -> BgColorDisplay<'_, Green, Self>

Change the background color to green
Source§

fn yellow(&self) -> FgColorDisplay<'_, Yellow, Self>

Change the foreground color to yellow
Source§

fn on_yellow(&self) -> BgColorDisplay<'_, Yellow, Self>

Change the background color to yellow
Source§

fn blue(&self) -> FgColorDisplay<'_, Blue, Self>

Change the foreground color to blue
Source§

fn on_blue(&self) -> BgColorDisplay<'_, Blue, Self>

Change the background color to blue
Source§

fn magenta(&self) -> FgColorDisplay<'_, Magenta, Self>

Change the foreground color to magenta
Source§

fn on_magenta(&self) -> BgColorDisplay<'_, Magenta, Self>

Change the background color to magenta
Source§

fn purple(&self) -> FgColorDisplay<'_, Magenta, Self>

Change the foreground color to purple
Source§

fn on_purple(&self) -> BgColorDisplay<'_, Magenta, Self>

Change the background color to purple
Source§

fn cyan(&self) -> FgColorDisplay<'_, Cyan, Self>

Change the foreground color to cyan
Source§

fn on_cyan(&self) -> BgColorDisplay<'_, Cyan, Self>

Change the background color to cyan
Source§

fn white(&self) -> FgColorDisplay<'_, White, Self>

Change the foreground color to white
Source§

fn on_white(&self) -> BgColorDisplay<'_, White, Self>

Change the background color to white
Source§

fn default_color(&self) -> FgColorDisplay<'_, Default, Self>

Change the foreground color to the terminal default
Source§

fn on_default_color(&self) -> BgColorDisplay<'_, Default, Self>

Change the background color to the terminal default
Source§

fn bright_black(&self) -> FgColorDisplay<'_, BrightBlack, Self>

Change the foreground color to bright black
Source§

fn on_bright_black(&self) -> BgColorDisplay<'_, BrightBlack, Self>

Change the background color to bright black
Source§

fn bright_red(&self) -> FgColorDisplay<'_, BrightRed, Self>

Change the foreground color to bright red
Source§

fn on_bright_red(&self) -> BgColorDisplay<'_, BrightRed, Self>

Change the background color to bright red
Source§

fn bright_green(&self) -> FgColorDisplay<'_, BrightGreen, Self>

Change the foreground color to bright green
Source§

fn on_bright_green(&self) -> BgColorDisplay<'_, BrightGreen, Self>

Change the background color to bright green
Source§

fn bright_yellow(&self) -> FgColorDisplay<'_, BrightYellow, Self>

Change the foreground color to bright yellow
Source§

fn on_bright_yellow(&self) -> BgColorDisplay<'_, BrightYellow, Self>

Change the background color to bright yellow
Source§

fn bright_blue(&self) -> FgColorDisplay<'_, BrightBlue, Self>

Change the foreground color to bright blue
Source§

fn on_bright_blue(&self) -> BgColorDisplay<'_, BrightBlue, Self>

Change the background color to bright blue
Source§

fn bright_magenta(&self) -> FgColorDisplay<'_, BrightMagenta, Self>

Change the foreground color to bright magenta
Source§

fn on_bright_magenta(&self) -> BgColorDisplay<'_, BrightMagenta, Self>

Change the background color to bright magenta
Source§

fn bright_purple(&self) -> FgColorDisplay<'_, BrightMagenta, Self>

Change the foreground color to bright purple
Source§

fn on_bright_purple(&self) -> BgColorDisplay<'_, BrightMagenta, Self>

Change the background color to bright purple
Source§

fn bright_cyan(&self) -> FgColorDisplay<'_, BrightCyan, Self>

Change the foreground color to bright cyan
Source§

fn on_bright_cyan(&self) -> BgColorDisplay<'_, BrightCyan, Self>

Change the background color to bright cyan
Source§

fn bright_white(&self) -> FgColorDisplay<'_, BrightWhite, Self>

Change the foreground color to bright white
Source§

fn on_bright_white(&self) -> BgColorDisplay<'_, BrightWhite, Self>

Change the background color to bright white
Source§

fn bold(&self) -> BoldDisplay<'_, Self>

Make the text bold
Source§

fn dimmed(&self) -> DimDisplay<'_, Self>

Make the text dim
Source§

fn italic(&self) -> ItalicDisplay<'_, Self>

Make the text italicized
Source§

fn underline(&self) -> UnderlineDisplay<'_, Self>

Make the text underlined
Make the text blink
Make the text blink (but fast!)
Source§

fn reversed(&self) -> ReversedDisplay<'_, Self>

Swap the foreground and background colors
Source§

fn hidden(&self) -> HiddenDisplay<'_, Self>

Hide the text
Source§

fn strikethrough(&self) -> StrikeThroughDisplay<'_, Self>

Cross out the text
Source§

fn color<Color>(&self, color: Color) -> FgDynColorDisplay<'_, Color, Self>
where Color: DynColor,

Set the foreground color at runtime. Only use if you do not know which color will be used at compile-time. If the color is constant, use either OwoColorize::fg or a color-specific method, such as OwoColorize::green, Read more
Source§

fn on_color<Color>(&self, color: Color) -> BgDynColorDisplay<'_, Color, Self>
where Color: DynColor,

Set the background color at runtime. Only use if you do not know what color to use at compile-time. If the color is constant, use either OwoColorize::bg or a color-specific method, such as OwoColorize::on_yellow, Read more
Source§

fn fg_rgb<const R: u8, const G: u8, const B: u8>( &self, ) -> FgColorDisplay<'_, CustomColor<R, G, B>, Self>

Set the foreground color to a specific RGB value.
Source§

fn bg_rgb<const R: u8, const G: u8, const B: u8>( &self, ) -> BgColorDisplay<'_, CustomColor<R, G, B>, Self>

Set the background color to a specific RGB value.
Source§

fn truecolor(&self, r: u8, g: u8, b: u8) -> FgDynColorDisplay<'_, Rgb, Self>

Sets the foreground color to an RGB value.
Source§

fn on_truecolor(&self, r: u8, g: u8, b: u8) -> BgDynColorDisplay<'_, Rgb, Self>

Sets the background color to an RGB value.
Source§

fn style(&self, style: Style) -> Styled<&Self>

Apply a runtime-determined style
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.