Struct lsp_types::DocumentSymbol
source · [−]pub struct DocumentSymbol {
pub name: String,
pub detail: Option<String>,
pub kind: SymbolKind,
pub tags: Option<Vec<SymbolTag>>,
pub deprecated: Option<bool>,
pub range: Range,
pub selection_range: Range,
pub children: Option<Vec<DocumentSymbol>>,
}
Expand description
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
name: String
The name of this symbol.
detail: Option<String>
More detail for this symbol, e.g the signature of a function. If not provided the name is used.
kind: SymbolKind
The kind of this symbol.
Tags for this completion item. since 3.16.0
deprecated: Option<bool>
Use tags instead
Indicates if this symbol is deprecated.
range: Range
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.
selection_range: Range
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: Option<Vec<DocumentSymbol>>
Children of this symbol, e.g. properties of a class.
Trait Implementations
sourceimpl Clone for DocumentSymbol
impl Clone for DocumentSymbol
sourcefn clone(&self) -> DocumentSymbol
fn clone(&self) -> DocumentSymbol
1.0.0 · sourcefn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source
. Read more