Struct languageserver_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.

Trait Implementations

impl Debug for DocumentSymbol
[src]

Formats the value using the given formatter. Read more

impl Eq for DocumentSymbol
[src]

impl PartialEq for DocumentSymbol
[src]

This method tests for self and other values to be equal, and is used by ==. Read more

This method tests for !=.

Auto Trait Implementations