Expand description
Basic syntax highlighting functionality.
This module uses librustc_astβs lexer to provide token-based highlighting for the HTML documentation generated by rustdoc.
Use the render_with_highlighting to highlight some rust code.
StructsΒ§
- Classifier π
- Processes program tokens, classifying strings of text by highlighting
category (Class).
- DecorationInfo π
- Decorations are represented as a map from CSS class to vector of character ranges. Each range will be wrapped in a span with that class.
- Decorations π
- Custom spans inserted into the source. Eg βscrape-examples uses this to highlight function calls
- HrefContext π
- This type is needed in case we want to render links on items to allow to go to their definition.
- LineInfo π
- PeekIter π
- This iterator comes from the same idea than βPeekableβ except that it allows to βpeekβ more than
just the next item by using peek_next. Thepeekmethod always returns the next item after the current one whereaspeek_nextwill return the next item after the last one peeked.
- TokenHandler π
- This type is used as a conveniency to prevent having to pass all its fields as arguments into the various functions (which became its methods).
- TokenIter π
EnumsΒ§
- Class π
- How a span of text is classified. Mostly corresponds to token kinds.
- Highlight π
- Tooltip π
FunctionsΒ§
- can_merge π
- Check if two Classcan be merged together. In the following rules, βunclassifiedβ meansNonebasically (since itβsOption<Class>). The following rules apply:
- empty_line_ πnumber 
- end_expansion π
- enter_span π
- Called when we start processing a span of text that should be highlighted.
The Classargument specifies how it should be highlighted.
- exit_span π
- Called at the end of a span of highlighted text.
- generate_link_ πto_ def 
- get_expansion π
- get_next_ πexpansion 
- get_real_ πident_ class 
- Classifies into identifier class; returns Noneif this is a non-keyword identifier.
- new_span π
- Convenient wrapper to create a Spanfrom a position in the file.
- render_example_ πwith_ highlighting 
- Highlights srcas an inline example, returning the HTML output.
- start_expansion π
- string π
- Called for a span of text. If the text should be highlighted differently
from the surrounding text, then the Classargument will be a value other thanNone.
- string_without_ πclosing_ tag 
- This function writes textintooutwith some modifications depending onklass:
- write_code π
- Convert the given srcsource code into HTML by adding classes for highlighting.
- write_footer π
- write_header π
- write_line_ πnumber 
- write_scraped_ πline_ number