Struct lsp::types::DocumentSymbol[][src]

pub struct DocumentSymbol {
    pub name: String,
    pub detail: Option<String>,
    pub kind: SymbolKind,
    pub deprecated: Option<bool>,
    pub range: Range,
    pub selection_range: Range,
    pub children: Option<Vec<DocumentSymbol>>,
}

Represents programming constructs like variables, classes, interfaces etc. that appear in a document. Document symbols can be hierarchical and they have two ranges: one that encloses its definition and one that points to its most interesting range, e.g. the range of an identifier.

Fields

The name of this symbol.

More detail for this symbol, e.g the signature of a function. If not provided the name is used.

The kind of this symbol.

Indicates if this symbol is deprecated.

The range enclosing this symbol not including leading/trailing whitespace but everything else like comments. This information is typically used to determine if the the clients cursor is inside the symbol to reveal in the symbol in the UI.

The range that should be selected and revealed when this symbol is being picked, e.g the name of a function. Must be contained by the the range.

Children of this symbol, e.g. properties of a class.

Methods

impl DocumentSymbol
[src]

Creates a new symbol information literal.

@param name The name of the symbol. @param detail The detail of the symbol. @param kind The kind of the symbol. @param range The range of the symbol. @param selectionRange The selectionRange of the symbol. @param children Children of the symbol.

Trait Implementations

impl Debug for DocumentSymbol
[src]

Formats the value using the given formatter. Read more

Auto Trait Implementations