Expand description

Utils for extracting, inspecting or transforming source code

Functions

Like snippet_block, but add braces if the expr is not an ExprKind::Block. Also takes an Option<String> which can be put inside the braces.
Returns a new Span that extends the original Span to the first non-whitespace char of the first line.
Returns the indentation of the line of a span
Returns the position just before rarrow
Reindent a multiline string with possibility of ignoring the first line.
Converts a span to a code snippet if available, otherwise returns the default.
Converts a span (from a block) to a code snippet if available, otherwise use default.
Same as snippet_block, but adapts the applicability level by the rules of snippet_with_applicability.
Gets a snippet of the indentation of the line of a span
Converts a span to a code snippet. Returns None if not available.
Same as snippet, but it adapts the applicability level by following rules:
Same as snippet_with_applicability, but first walks the span up to the given context. This will result in the macro call, rather then the expansion, if the span is from a child context. If the span is not from a child context, it will be used directly instead.
Same as snippet, but should only be used when it’s clear that the input span is not a macro argument.
Trims the whitespace from the start and the end of the span.
Walks the span up to the target context, thereby returning the macro call site if the span is inside a macro expansion, or the original span if it is not. Note this will return None in the case of the span being in a macro expansion, but the target context is from expanding a macro argument.
Removes block comments from the given Vec of lines.