pub struct Backend {
    pub client: Client,
    pub stdlib_completions: HashMap<String, CompletionItem>,
    pub stdlib_signatures: HashMap<String, SignatureHelp>,
    pub token_types: Vec<SemanticTokenType>,
    pub token_map: DashMap<String, Vec<Token>>,
    pub ast_map: DashMap<String, Program>,
    pub current_code_map: DashMap<String, String>,
    pub diagnostics_map: DashMap<String, DocumentDiagnosticReport>,
    pub symbols_map: DashMap<String, Vec<DocumentSymbol>>,
    pub semantic_tokens_map: DashMap<String, Vec<SemanticToken>>,
}Expand description
The lsp server backend.
Fields§
§client: ClientThe client for the backend.
stdlib_completions: HashMap<String, CompletionItem>The stdlib completions for the language.
stdlib_signatures: HashMap<String, SignatureHelp>The stdlib signatures for the language.
token_types: Vec<SemanticTokenType>The types of tokens the server supports.
token_map: DashMap<String, Vec<Token>>Token maps.
ast_map: DashMap<String, Program>AST maps.
current_code_map: DashMap<String, String>Current code.
diagnostics_map: DashMap<String, DocumentDiagnosticReport>Diagnostics.
symbols_map: DashMap<String, Vec<DocumentSymbol>>Symbols map.
semantic_tokens_map: DashMap<String, Vec<SemanticToken>>Semantic tokens map.
Trait Implementations§
source§impl LanguageServer for Backend
 
impl LanguageServer for Backend
source§fn initialize<'life0, 'async_trait>(
    &'life0 self,
    params: InitializeParams
) -> Pin<Box<dyn Future<Output = RpcResult<InitializeResult>> + Send + 'async_trait>>where
    Self: 'async_trait,
    'life0: 'async_trait,
 
fn initialize<'life0, 'async_trait>( &'life0 self, params: InitializeParams ) -> Pin<Box<dyn Future<Output = RpcResult<InitializeResult>> + Send + 'async_trait>>where Self: 'async_trait, 'life0: 'async_trait,
The 
initialize request is the first request sent from the client to the server. Read moresource§fn initialized<'life0, 'async_trait>(
    &'life0 self,
    params: InitializedParams
) -> Pin<Box<dyn Future<Output = ()> + Send + 'async_trait>>where
    Self: 'async_trait,
    'life0: 'async_trait,
 
fn initialized<'life0, 'async_trait>( &'life0 self, params: InitializedParams ) -> Pin<Box<dyn Future<Output = ()> + Send + 'async_trait>>where Self: 'async_trait, 'life0: 'async_trait,
The 
initialized notification is sent from the client to the server after the client
received the result of the initialize request but before the client sends anything else. Read moresource§fn shutdown<'life0, 'async_trait>(
    &'life0 self
) -> Pin<Box<dyn Future<Output = RpcResult<()>> + Send + 'async_trait>>where
    Self: 'async_trait,
    'life0: 'async_trait,
 
fn shutdown<'life0, 'async_trait>( &'life0 self ) -> Pin<Box<dyn Future<Output = RpcResult<()>> + Send + 'async_trait>>where Self: 'async_trait, 'life0: 'async_trait,
source§fn did_change_workspace_folders<'life0, 'async_trait>(
    &'life0 self,
    __arg1: DidChangeWorkspaceFoldersParams
) -> Pin<Box<dyn Future<Output = ()> + Send + 'async_trait>>where
    Self: 'async_trait,
    'life0: 'async_trait,
 
fn did_change_workspace_folders<'life0, 'async_trait>( &'life0 self, __arg1: DidChangeWorkspaceFoldersParams ) -> Pin<Box<dyn Future<Output = ()> + Send + 'async_trait>>where Self: 'async_trait, 'life0: 'async_trait,
The 
workspace/didChangeWorkspaceFolders notification is sent from the client to the
server to inform about workspace folder configuration changes. Read moresource§fn did_change_configuration<'life0, 'async_trait>(
    &'life0 self,
    __arg1: DidChangeConfigurationParams
) -> Pin<Box<dyn Future<Output = ()> + Send + 'async_trait>>where
    Self: 'async_trait,
    'life0: 'async_trait,
 
fn did_change_configuration<'life0, 'async_trait>( &'life0 self, __arg1: DidChangeConfigurationParams ) -> Pin<Box<dyn Future<Output = ()> + Send + 'async_trait>>where Self: 'async_trait, 'life0: 'async_trait,
The 
workspace/didChangeConfiguration notification is sent from the client to the server
to signal the change of configuration settings.source§fn did_change_watched_files<'life0, 'async_trait>(
    &'life0 self,
    __arg1: DidChangeWatchedFilesParams
) -> Pin<Box<dyn Future<Output = ()> + Send + 'async_trait>>where
    Self: 'async_trait,
    'life0: 'async_trait,
 
fn did_change_watched_files<'life0, 'async_trait>( &'life0 self, __arg1: DidChangeWatchedFilesParams ) -> Pin<Box<dyn Future<Output = ()> + Send + 'async_trait>>where Self: 'async_trait, 'life0: 'async_trait,
The 
workspace/didChangeWatchedFiles notification is sent from the client to the server
when the client detects changes to files watched by the language client. Read moresource§fn did_open<'life0, 'async_trait>(
    &'life0 self,
    params: DidOpenTextDocumentParams
) -> Pin<Box<dyn Future<Output = ()> + Send + 'async_trait>>where
    Self: 'async_trait,
    'life0: 'async_trait,
 
fn did_open<'life0, 'async_trait>( &'life0 self, params: DidOpenTextDocumentParams ) -> Pin<Box<dyn Future<Output = ()> + Send + 'async_trait>>where Self: 'async_trait, 'life0: 'async_trait,
The 
textDocument/didOpen notification is sent from the client to the server to signal
that a new text document has been opened by the client. Read moresource§fn did_change<'life0, 'async_trait>(
    &'life0 self,
    params: DidChangeTextDocumentParams
) -> Pin<Box<dyn Future<Output = ()> + Send + 'async_trait>>where
    Self: 'async_trait,
    'life0: 'async_trait,
 
fn did_change<'life0, 'async_trait>( &'life0 self, params: DidChangeTextDocumentParams ) -> Pin<Box<dyn Future<Output = ()> + Send + 'async_trait>>where Self: 'async_trait, 'life0: 'async_trait,
The 
textDocument/didChange notification is sent from the client to the server to signal
changes to a text document. Read moresource§fn did_save<'life0, 'async_trait>(
    &'life0 self,
    params: DidSaveTextDocumentParams
) -> Pin<Box<dyn Future<Output = ()> + Send + 'async_trait>>where
    Self: 'async_trait,
    'life0: 'async_trait,
 
fn did_save<'life0, 'async_trait>( &'life0 self, params: DidSaveTextDocumentParams ) -> Pin<Box<dyn Future<Output = ()> + Send + 'async_trait>>where Self: 'async_trait, 'life0: 'async_trait,
The 
textDocument/didSave notification is sent from the client to the server when the
document was saved in the client.source§fn did_close<'life0, 'async_trait>(
    &'life0 self,
    __arg1: DidCloseTextDocumentParams
) -> Pin<Box<dyn Future<Output = ()> + Send + 'async_trait>>where
    Self: 'async_trait,
    'life0: 'async_trait,
 
fn did_close<'life0, 'async_trait>( &'life0 self, __arg1: DidCloseTextDocumentParams ) -> Pin<Box<dyn Future<Output = ()> + Send + 'async_trait>>where Self: 'async_trait, 'life0: 'async_trait,
The 
textDocument/didClose notification is sent from the client to the server when the
document got closed in the client. Read moresource§fn hover<'life0, 'async_trait>(
    &'life0 self,
    params: HoverParams
) -> Pin<Box<dyn Future<Output = RpcResult<Option<Hover>>> + Send + 'async_trait>>where
    Self: 'async_trait,
    'life0: 'async_trait,
 
fn hover<'life0, 'async_trait>( &'life0 self, params: HoverParams ) -> Pin<Box<dyn Future<Output = RpcResult<Option<Hover>>> + Send + 'async_trait>>where Self: 'async_trait, 'life0: 'async_trait,
The 
textDocument/hover request asks the server for hover information at a given text
document position. Read moresource§fn completion<'life0, 'async_trait>(
    &'life0 self,
    params: CompletionParams
) -> Pin<Box<dyn Future<Output = RpcResult<Option<CompletionResponse>>> + Send + 'async_trait>>where
    Self: 'async_trait,
    'life0: 'async_trait,
 
fn completion<'life0, 'async_trait>( &'life0 self, params: CompletionParams ) -> Pin<Box<dyn Future<Output = RpcResult<Option<CompletionResponse>>> + Send + 'async_trait>>where Self: 'async_trait, 'life0: 'async_trait,
The 
textDocument/completion request is sent from the client to the server to compute
completion items at a given cursor position. Read moresource§fn diagnostic<'life0, 'async_trait>(
    &'life0 self,
    params: DocumentDiagnosticParams
) -> Pin<Box<dyn Future<Output = RpcResult<DocumentDiagnosticReportResult>> + Send + 'async_trait>>where
    Self: 'async_trait,
    'life0: 'async_trait,
 
fn diagnostic<'life0, 'async_trait>( &'life0 self, params: DocumentDiagnosticParams ) -> Pin<Box<dyn Future<Output = RpcResult<DocumentDiagnosticReportResult>> + Send + 'async_trait>>where Self: 'async_trait, 'life0: 'async_trait,
The 
textDocument/diagnostic request is sent from the client to the server to ask the
server to compute the diagnostics for a given document. Read moresource§fn signature_help<'life0, 'async_trait>(
    &'life0 self,
    params: SignatureHelpParams
) -> Pin<Box<dyn Future<Output = RpcResult<Option<SignatureHelp>>> + Send + 'async_trait>>where
    Self: 'async_trait,
    'life0: 'async_trait,
 
fn signature_help<'life0, 'async_trait>( &'life0 self, params: SignatureHelpParams ) -> Pin<Box<dyn Future<Output = RpcResult<Option<SignatureHelp>>> + Send + 'async_trait>>where Self: 'async_trait, 'life0: 'async_trait,
The 
textDocument/signatureHelp request is sent from the client to the server to request
signature information at a given cursor position.source§fn inlay_hint<'life0, 'async_trait>(
    &'life0 self,
    _params: InlayHintParams
) -> Pin<Box<dyn Future<Output = RpcResult<Option<Vec<InlayHint>>>> + Send + 'async_trait>>where
    Self: 'async_trait,
    'life0: 'async_trait,
 
fn inlay_hint<'life0, 'async_trait>( &'life0 self, _params: InlayHintParams ) -> Pin<Box<dyn Future<Output = RpcResult<Option<Vec<InlayHint>>>> + Send + 'async_trait>>where Self: 'async_trait, 'life0: 'async_trait,
The 
textDocument/inlayHint request is sent from the client to the server to compute
inlay hints for a given (text document, range) tuple that may be rendered in the editor
in place with other text. Read moresource§fn semantic_tokens_full<'life0, 'async_trait>(
    &'life0 self,
    params: SemanticTokensParams
) -> Pin<Box<dyn Future<Output = RpcResult<Option<SemanticTokensResult>>> + Send + 'async_trait>>where
    Self: 'async_trait,
    'life0: 'async_trait,
 
fn semantic_tokens_full<'life0, 'async_trait>( &'life0 self, params: SemanticTokensParams ) -> Pin<Box<dyn Future<Output = RpcResult<Option<SemanticTokensResult>>> + Send + 'async_trait>>where Self: 'async_trait, 'life0: 'async_trait,
The 
textDocument/semanticTokens/full request is sent from the client to the server to
resolve the semantic tokens of a given file. Read moresource§fn document_symbol<'life0, 'async_trait>(
    &'life0 self,
    params: DocumentSymbolParams
) -> Pin<Box<dyn Future<Output = RpcResult<Option<DocumentSymbolResponse>>> + Send + 'async_trait>>where
    Self: 'async_trait,
    'life0: 'async_trait,
 
fn document_symbol<'life0, 'async_trait>( &'life0 self, params: DocumentSymbolParams ) -> Pin<Box<dyn Future<Output = RpcResult<Option<DocumentSymbolResponse>>> + Send + 'async_trait>>where Self: 'async_trait, 'life0: 'async_trait,
The 
textDocument/documentSymbol request is sent from the client to the server to
retrieve all symbols found in a given text document. Read moresource§fn formatting<'life0, 'async_trait>(
    &'life0 self,
    params: DocumentFormattingParams
) -> Pin<Box<dyn Future<Output = RpcResult<Option<Vec<TextEdit>>>> + Send + 'async_trait>>where
    Self: 'async_trait,
    'life0: 'async_trait,
 
fn formatting<'life0, 'async_trait>( &'life0 self, params: DocumentFormattingParams ) -> Pin<Box<dyn Future<Output = RpcResult<Option<Vec<TextEdit>>>> + Send + 'async_trait>>where Self: 'async_trait, 'life0: 'async_trait,
The 
textDocument/formatting request is sent from the client to the server to format a
whole document.source§fn rename<'life0, 'async_trait>(
    &'life0 self,
    params: RenameParams
) -> Pin<Box<dyn Future<Output = RpcResult<Option<WorkspaceEdit>>> + Send + 'async_trait>>where
    Self: 'async_trait,
    'life0: 'async_trait,
 
fn rename<'life0, 'async_trait>( &'life0 self, params: RenameParams ) -> Pin<Box<dyn Future<Output = RpcResult<Option<WorkspaceEdit>>> + Send + 'async_trait>>where Self: 'async_trait, 'life0: 'async_trait,
The 
textDocument/rename request is sent from the client to the server to ask the server
to compute a workspace change so that the client can perform a workspace-wide rename of a
symbol.source§fn will_save<'life0, 'async_trait>(
    &'life0 self,
    params: WillSaveTextDocumentParams
) -> Pin<Box<dyn Future<Output = ()> + Send + 'async_trait>>where
    'life0: 'async_trait,
    Self: 'async_trait,
 
fn will_save<'life0, 'async_trait>( &'life0 self, params: WillSaveTextDocumentParams ) -> Pin<Box<dyn Future<Output = ()> + Send + 'async_trait>>where 'life0: 'async_trait, Self: 'async_trait,
The 
textDocument/willSave notification is sent from the client to the server before the
document is actually saved.source§fn will_save_wait_until<'life0, 'async_trait>(
    &'life0 self,
    params: WillSaveTextDocumentParams
) -> Pin<Box<dyn Future<Output = Result<Option<Vec<TextEdit>>, Error>> + Send + 'async_trait>>where
    'life0: 'async_trait,
    Self: 'async_trait,
 
fn will_save_wait_until<'life0, 'async_trait>( &'life0 self, params: WillSaveTextDocumentParams ) -> Pin<Box<dyn Future<Output = Result<Option<Vec<TextEdit>>, Error>> + Send + 'async_trait>>where 'life0: 'async_trait, Self: 'async_trait,
The 
textDocument/willSaveWaitUntil request is sent from the client to the server before
the document is actually saved. Read moresource§fn goto_declaration<'life0, 'async_trait>(
    &'life0 self,
    params: GotoDefinitionParams
) -> Pin<Box<dyn Future<Output = Result<Option<GotoDefinitionResponse>, Error>> + Send + 'async_trait>>where
    'life0: 'async_trait,
    Self: 'async_trait,
 
fn goto_declaration<'life0, 'async_trait>( &'life0 self, params: GotoDefinitionParams ) -> Pin<Box<dyn Future<Output = Result<Option<GotoDefinitionResponse>, Error>> + Send + 'async_trait>>where 'life0: 'async_trait, Self: 'async_trait,
The 
textDocument/declaration request asks the server for the declaration location of a
symbol at a given text document position. Read moresource§fn goto_definition<'life0, 'async_trait>(
    &'life0 self,
    params: GotoDefinitionParams
) -> Pin<Box<dyn Future<Output = Result<Option<GotoDefinitionResponse>, Error>> + Send + 'async_trait>>where
    'life0: 'async_trait,
    Self: 'async_trait,
 
fn goto_definition<'life0, 'async_trait>( &'life0 self, params: GotoDefinitionParams ) -> Pin<Box<dyn Future<Output = Result<Option<GotoDefinitionResponse>, Error>> + Send + 'async_trait>>where 'life0: 'async_trait, Self: 'async_trait,
The 
textDocument/definition request asks the server for the definition location of a
symbol at a given text document position. Read moresource§fn goto_type_definition<'life0, 'async_trait>(
    &'life0 self,
    params: GotoDefinitionParams
) -> Pin<Box<dyn Future<Output = Result<Option<GotoDefinitionResponse>, Error>> + Send + 'async_trait>>where
    'life0: 'async_trait,
    Self: 'async_trait,
 
fn goto_type_definition<'life0, 'async_trait>( &'life0 self, params: GotoDefinitionParams ) -> Pin<Box<dyn Future<Output = Result<Option<GotoDefinitionResponse>, Error>> + Send + 'async_trait>>where 'life0: 'async_trait, Self: 'async_trait,
The 
textDocument/typeDefinition request asks the server for the type definition location of
a symbol at a given text document position. Read moresource§fn goto_implementation<'life0, 'async_trait>(
    &'life0 self,
    params: GotoDefinitionParams
) -> Pin<Box<dyn Future<Output = Result<Option<GotoDefinitionResponse>, Error>> + Send + 'async_trait>>where
    'life0: 'async_trait,
    Self: 'async_trait,
 
fn goto_implementation<'life0, 'async_trait>( &'life0 self, params: GotoDefinitionParams ) -> Pin<Box<dyn Future<Output = Result<Option<GotoDefinitionResponse>, Error>> + Send + 'async_trait>>where 'life0: 'async_trait, Self: 'async_trait,
The 
textDocument/implementation request is sent from the client to the server to resolve
the implementation location of a symbol at a given text document position. Read moresource§fn references<'life0, 'async_trait>(
    &'life0 self,
    params: ReferenceParams
) -> Pin<Box<dyn Future<Output = Result<Option<Vec<Location>>, Error>> + Send + 'async_trait>>where
    'life0: 'async_trait,
    Self: 'async_trait,
 
fn references<'life0, 'async_trait>( &'life0 self, params: ReferenceParams ) -> Pin<Box<dyn Future<Output = Result<Option<Vec<Location>>, Error>> + Send + 'async_trait>>where 'life0: 'async_trait, Self: 'async_trait,
The 
textDocument/references request is sent from the client to the server to resolve
project-wide references for the symbol denoted by the given text document position.source§fn prepare_call_hierarchy<'life0, 'async_trait>(
    &'life0 self,
    params: CallHierarchyPrepareParams
) -> Pin<Box<dyn Future<Output = Result<Option<Vec<CallHierarchyItem>>, Error>> + Send + 'async_trait>>where
    'life0: 'async_trait,
    Self: 'async_trait,
 
fn prepare_call_hierarchy<'life0, 'async_trait>( &'life0 self, params: CallHierarchyPrepareParams ) -> Pin<Box<dyn Future<Output = Result<Option<Vec<CallHierarchyItem>>, Error>> + Send + 'async_trait>>where 'life0: 'async_trait, Self: 'async_trait,
The 
textDocument/prepareCallHierarchy request is sent from the client to the server to
return a call hierarchy for the language element of given text document positions. Read moresource§fn incoming_calls<'life0, 'async_trait>(
    &'life0 self,
    params: CallHierarchyIncomingCallsParams
) -> Pin<Box<dyn Future<Output = Result<Option<Vec<CallHierarchyIncomingCall>>, Error>> + Send + 'async_trait>>where
    'life0: 'async_trait,
    Self: 'async_trait,
 
fn incoming_calls<'life0, 'async_trait>( &'life0 self, params: CallHierarchyIncomingCallsParams ) -> Pin<Box<dyn Future<Output = Result<Option<Vec<CallHierarchyIncomingCall>>, Error>> + Send + 'async_trait>>where 'life0: 'async_trait, Self: 'async_trait,
The 
callHierarchy/incomingCalls request is sent from the client to the server to
resolve incoming calls for a given call hierarchy item. Read moresource§fn outgoing_calls<'life0, 'async_trait>(
    &'life0 self,
    params: CallHierarchyOutgoingCallsParams
) -> Pin<Box<dyn Future<Output = Result<Option<Vec<CallHierarchyOutgoingCall>>, Error>> + Send + 'async_trait>>where
    'life0: 'async_trait,
    Self: 'async_trait,
 
fn outgoing_calls<'life0, 'async_trait>( &'life0 self, params: CallHierarchyOutgoingCallsParams ) -> Pin<Box<dyn Future<Output = Result<Option<Vec<CallHierarchyOutgoingCall>>, Error>> + Send + 'async_trait>>where 'life0: 'async_trait, Self: 'async_trait,
The 
callHierarchy/outgoingCalls request is sent from the client to the server to
resolve outgoing calls for a given call hierarchy item. Read moresource§fn prepare_type_hierarchy<'life0, 'async_trait>(
    &'life0 self,
    params: TypeHierarchyPrepareParams
) -> Pin<Box<dyn Future<Output = Result<Option<Vec<TypeHierarchyItem>>, Error>> + Send + 'async_trait>>where
    'life0: 'async_trait,
    Self: 'async_trait,
 
fn prepare_type_hierarchy<'life0, 'async_trait>( &'life0 self, params: TypeHierarchyPrepareParams ) -> Pin<Box<dyn Future<Output = Result<Option<Vec<TypeHierarchyItem>>, Error>> + Send + 'async_trait>>where 'life0: 'async_trait, Self: 'async_trait,
The 
textDocument/prepareTypeHierarchy request is sent from the client to the server to
return a type hierarchy for the language element of given text document positions. Read moresource§fn supertypes<'life0, 'async_trait>(
    &'life0 self,
    params: TypeHierarchySupertypesParams
) -> Pin<Box<dyn Future<Output = Result<Option<Vec<TypeHierarchyItem>>, Error>> + Send + 'async_trait>>where
    'life0: 'async_trait,
    Self: 'async_trait,
 
fn supertypes<'life0, 'async_trait>( &'life0 self, params: TypeHierarchySupertypesParams ) -> Pin<Box<dyn Future<Output = Result<Option<Vec<TypeHierarchyItem>>, Error>> + Send + 'async_trait>>where 'life0: 'async_trait, Self: 'async_trait,
The [
typeHierarchy/supertypes] request is sent from the client to the server to resolve
the supertypes for a given type hierarchy item. Read moresource§fn subtypes<'life0, 'async_trait>(
    &'life0 self,
    params: TypeHierarchySubtypesParams
) -> Pin<Box<dyn Future<Output = Result<Option<Vec<TypeHierarchyItem>>, Error>> + Send + 'async_trait>>where
    'life0: 'async_trait,
    Self: 'async_trait,
 
fn subtypes<'life0, 'async_trait>( &'life0 self, params: TypeHierarchySubtypesParams ) -> Pin<Box<dyn Future<Output = Result<Option<Vec<TypeHierarchyItem>>, Error>> + Send + 'async_trait>>where 'life0: 'async_trait, Self: 'async_trait,
The [
typeHierarchy/subtypes] request is sent from the client to the server to resolve
the subtypes for a given type hierarchy item. Read moresource§fn document_highlight<'life0, 'async_trait>(
    &'life0 self,
    params: DocumentHighlightParams
) -> Pin<Box<dyn Future<Output = Result<Option<Vec<DocumentHighlight>>, Error>> + Send + 'async_trait>>where
    'life0: 'async_trait,
    Self: 'async_trait,
 
fn document_highlight<'life0, 'async_trait>( &'life0 self, params: DocumentHighlightParams ) -> Pin<Box<dyn Future<Output = Result<Option<Vec<DocumentHighlight>>, Error>> + Send + 'async_trait>>where 'life0: 'async_trait, Self: 'async_trait,
The 
textDocument/documentHighlight request is sent from the client to the server to
resolve appropriate highlights for a given text document position. Read moresource§fn document_link<'life0, 'async_trait>(
    &'life0 self,
    params: DocumentLinkParams
) -> Pin<Box<dyn Future<Output = Result<Option<Vec<DocumentLink>>, Error>> + Send + 'async_trait>>where
    'life0: 'async_trait,
    Self: 'async_trait,
 
fn document_link<'life0, 'async_trait>( &'life0 self, params: DocumentLinkParams ) -> Pin<Box<dyn Future<Output = Result<Option<Vec<DocumentLink>>, Error>> + Send + 'async_trait>>where 'life0: 'async_trait, Self: 'async_trait,
The 
textDocument/documentLink request is sent from the client to the server to request
the location of links in a document. Read moresource§fn document_link_resolve<'life0, 'async_trait>(
    &'life0 self,
    params: DocumentLink
) -> Pin<Box<dyn Future<Output = Result<DocumentLink, Error>> + Send + 'async_trait>>where
    'life0: 'async_trait,
    Self: 'async_trait,
 
fn document_link_resolve<'life0, 'async_trait>( &'life0 self, params: DocumentLink ) -> Pin<Box<dyn Future<Output = Result<DocumentLink, Error>> + Send + 'async_trait>>where 'life0: 'async_trait, Self: 'async_trait,
The 
documentLink/resolve request is sent from the client to the server to resolve the
target of a given document link. Read moresource§fn code_lens<'life0, 'async_trait>(
    &'life0 self,
    params: CodeLensParams
) -> Pin<Box<dyn Future<Output = Result<Option<Vec<CodeLens>>, Error>> + Send + 'async_trait>>where
    'life0: 'async_trait,
    Self: 'async_trait,
 
fn code_lens<'life0, 'async_trait>( &'life0 self, params: CodeLensParams ) -> Pin<Box<dyn Future<Output = Result<Option<Vec<CodeLens>>, Error>> + Send + 'async_trait>>where 'life0: 'async_trait, Self: 'async_trait,
The 
textDocument/codeLens request is sent from the client to the server to compute code
lenses for a given text document.source§fn code_lens_resolve<'life0, 'async_trait>(
    &'life0 self,
    params: CodeLens
) -> Pin<Box<dyn Future<Output = Result<CodeLens, Error>> + Send + 'async_trait>>where
    'life0: 'async_trait,
    Self: 'async_trait,
 
fn code_lens_resolve<'life0, 'async_trait>( &'life0 self, params: CodeLens ) -> Pin<Box<dyn Future<Output = Result<CodeLens, Error>> + Send + 'async_trait>>where 'life0: 'async_trait, Self: 'async_trait,
The 
codeLens/resolve request is sent from the client to the server to resolve the
command for a given code lens item.source§fn folding_range<'life0, 'async_trait>(
    &'life0 self,
    params: FoldingRangeParams
) -> Pin<Box<dyn Future<Output = Result<Option<Vec<FoldingRange>>, Error>> + Send + 'async_trait>>where
    'life0: 'async_trait,
    Self: 'async_trait,
 
fn folding_range<'life0, 'async_trait>( &'life0 self, params: FoldingRangeParams ) -> Pin<Box<dyn Future<Output = Result<Option<Vec<FoldingRange>>, Error>> + Send + 'async_trait>>where 'life0: 'async_trait, Self: 'async_trait,
The 
textDocument/foldingRange request is sent from the client to the server to return
all folding ranges found in a given text document. Read moresource§fn selection_range<'life0, 'async_trait>(
    &'life0 self,
    params: SelectionRangeParams
) -> Pin<Box<dyn Future<Output = Result<Option<Vec<SelectionRange>>, Error>> + Send + 'async_trait>>where
    'life0: 'async_trait,
    Self: 'async_trait,
 
fn selection_range<'life0, 'async_trait>( &'life0 self, params: SelectionRangeParams ) -> Pin<Box<dyn Future<Output = Result<Option<Vec<SelectionRange>>, Error>> + Send + 'async_trait>>where 'life0: 'async_trait, Self: 'async_trait,
The 
textDocument/selectionRange request is sent from the client to the server to return
suggested selection ranges at an array of given positions. A selection range is a range
around the cursor position which the user might be interested in selecting. Read moresource§fn semantic_tokens_full_delta<'life0, 'async_trait>(
    &'life0 self,
    params: SemanticTokensDeltaParams
) -> Pin<Box<dyn Future<Output = Result<Option<SemanticTokensFullDeltaResult>, Error>> + Send + 'async_trait>>where
    'life0: 'async_trait,
    Self: 'async_trait,
 
fn semantic_tokens_full_delta<'life0, 'async_trait>( &'life0 self, params: SemanticTokensDeltaParams ) -> Pin<Box<dyn Future<Output = Result<Option<SemanticTokensFullDeltaResult>, Error>> + Send + 'async_trait>>where 'life0: 'async_trait, Self: 'async_trait,
The 
textDocument/semanticTokens/full/delta request is sent from the client to the server to
resolve the semantic tokens of a given file, returning only the delta. Read moresource§fn semantic_tokens_range<'life0, 'async_trait>(
    &'life0 self,
    params: SemanticTokensRangeParams
) -> Pin<Box<dyn Future<Output = Result<Option<SemanticTokensRangeResult>, Error>> + Send + 'async_trait>>where
    'life0: 'async_trait,
    Self: 'async_trait,
 
fn semantic_tokens_range<'life0, 'async_trait>( &'life0 self, params: SemanticTokensRangeParams ) -> Pin<Box<dyn Future<Output = Result<Option<SemanticTokensRangeResult>, Error>> + Send + 'async_trait>>where 'life0: 'async_trait, Self: 'async_trait,
The 
textDocument/semanticTokens/range request is sent from the client to the server to
resolve the semantic tokens for the visible range of a given file. Read moresource§fn inline_value<'life0, 'async_trait>(
    &'life0 self,
    params: InlineValueParams
) -> Pin<Box<dyn Future<Output = Result<Option<Vec<InlineValue>>, Error>> + Send + 'async_trait>>where
    'life0: 'async_trait,
    Self: 'async_trait,
 
fn inline_value<'life0, 'async_trait>( &'life0 self, params: InlineValueParams ) -> Pin<Box<dyn Future<Output = Result<Option<Vec<InlineValue>>, Error>> + Send + 'async_trait>>where 'life0: 'async_trait, Self: 'async_trait,
The 
textDocument/inlineValue request is sent from the client to the server to compute
inline values for a given text document that may be rendered in the editor at the end of
lines. Read moresource§fn inlay_hint_resolve<'life0, 'async_trait>(
    &'life0 self,
    params: InlayHint
) -> Pin<Box<dyn Future<Output = Result<InlayHint, Error>> + Send + 'async_trait>>where
    'life0: 'async_trait,
    Self: 'async_trait,
 
fn inlay_hint_resolve<'life0, 'async_trait>( &'life0 self, params: InlayHint ) -> Pin<Box<dyn Future<Output = Result<InlayHint, Error>> + Send + 'async_trait>>where 'life0: 'async_trait, Self: 'async_trait,
The 
inlayHint/resolve request is sent from the client to the server to resolve
additional information for a given inlay hint. Read moresource§fn moniker<'life0, 'async_trait>(
    &'life0 self,
    params: MonikerParams
) -> Pin<Box<dyn Future<Output = Result<Option<Vec<Moniker>>, Error>> + Send + 'async_trait>>where
    'life0: 'async_trait,
    Self: 'async_trait,
 
fn moniker<'life0, 'async_trait>( &'life0 self, params: MonikerParams ) -> Pin<Box<dyn Future<Output = Result<Option<Vec<Moniker>>, Error>> + Send + 'async_trait>>where 'life0: 'async_trait, Self: 'async_trait,
The 
textDocument/moniker request is sent from the client to the server to get the
symbol monikers for a given text document position. Read moresource§fn completion_resolve<'life0, 'async_trait>(
    &'life0 self,
    params: CompletionItem
) -> Pin<Box<dyn Future<Output = Result<CompletionItem, Error>> + Send + 'async_trait>>where
    'life0: 'async_trait,
    Self: 'async_trait,
 
fn completion_resolve<'life0, 'async_trait>( &'life0 self, params: CompletionItem ) -> Pin<Box<dyn Future<Output = Result<CompletionItem, Error>> + Send + 'async_trait>>where 'life0: 'async_trait, Self: 'async_trait,
The 
completionItem/resolve request is sent from the client to the server to resolve
additional information for a given completion item.source§fn workspace_diagnostic<'life0, 'async_trait>(
    &'life0 self,
    params: WorkspaceDiagnosticParams
) -> Pin<Box<dyn Future<Output = Result<WorkspaceDiagnosticReportResult, Error>> + Send + 'async_trait>>where
    'life0: 'async_trait,
    Self: 'async_trait,
 
fn workspace_diagnostic<'life0, 'async_trait>( &'life0 self, params: WorkspaceDiagnosticParams ) -> Pin<Box<dyn Future<Output = Result<WorkspaceDiagnosticReportResult, Error>> + Send + 'async_trait>>where 'life0: 'async_trait, Self: 'async_trait,
The 
workspace/diagnostic request is sent from the client to the server to ask the
server to compute workspace wide diagnostics which previously where pushed from the server
to the client. Read moresource§fn code_action<'life0, 'async_trait>(
    &'life0 self,
    params: CodeActionParams
) -> Pin<Box<dyn Future<Output = Result<Option<Vec<CodeActionOrCommand>>, Error>> + Send + 'async_trait>>where
    'life0: 'async_trait,
    Self: 'async_trait,
 
fn code_action<'life0, 'async_trait>( &'life0 self, params: CodeActionParams ) -> Pin<Box<dyn Future<Output = Result<Option<Vec<CodeActionOrCommand>>, Error>> + Send + 'async_trait>>where 'life0: 'async_trait, Self: 'async_trait,
The 
textDocument/codeAction request is sent from the client to the server to compute
commands for a given text document and range. These commands are typically code fixes to
either fix problems or to beautify/refactor code. Read moresource§fn code_action_resolve<'life0, 'async_trait>(
    &'life0 self,
    params: CodeAction
) -> Pin<Box<dyn Future<Output = Result<CodeAction, Error>> + Send + 'async_trait>>where
    'life0: 'async_trait,
    Self: 'async_trait,
 
fn code_action_resolve<'life0, 'async_trait>( &'life0 self, params: CodeAction ) -> Pin<Box<dyn Future<Output = Result<CodeAction, Error>> + Send + 'async_trait>>where 'life0: 'async_trait, Self: 'async_trait,
The 
codeAction/resolve request is sent from the client to the server to resolve
additional information for a given code action. Read moresource§fn document_color<'life0, 'async_trait>(
    &'life0 self,
    params: DocumentColorParams
) -> Pin<Box<dyn Future<Output = Result<Vec<ColorInformation>, Error>> + Send + 'async_trait>>where
    'life0: 'async_trait,
    Self: 'async_trait,
 
fn document_color<'life0, 'async_trait>( &'life0 self, params: DocumentColorParams ) -> Pin<Box<dyn Future<Output = Result<Vec<ColorInformation>, Error>> + Send + 'async_trait>>where 'life0: 'async_trait, Self: 'async_trait,
The 
textDocument/documentColor request is sent from the client to the server to list
all color references found in a given text document. Along with the range, a color value in
RGB is returned. Read moresource§fn color_presentation<'life0, 'async_trait>(
    &'life0 self,
    params: ColorPresentationParams
) -> Pin<Box<dyn Future<Output = Result<Vec<ColorPresentation>, Error>> + Send + 'async_trait>>where
    'life0: 'async_trait,
    Self: 'async_trait,
 
fn color_presentation<'life0, 'async_trait>( &'life0 self, params: ColorPresentationParams ) -> Pin<Box<dyn Future<Output = Result<Vec<ColorPresentation>, Error>> + Send + 'async_trait>>where 'life0: 'async_trait, Self: 'async_trait,
The 
textDocument/colorPresentation request is sent from the client to the server to
obtain a list of presentations for a color value at a given location. Read moresource§fn range_formatting<'life0, 'async_trait>(
    &'life0 self,
    params: DocumentRangeFormattingParams
) -> Pin<Box<dyn Future<Output = Result<Option<Vec<TextEdit>>, Error>> + Send + 'async_trait>>where
    'life0: 'async_trait,
    Self: 'async_trait,
 
fn range_formatting<'life0, 'async_trait>( &'life0 self, params: DocumentRangeFormattingParams ) -> Pin<Box<dyn Future<Output = Result<Option<Vec<TextEdit>>, Error>> + Send + 'async_trait>>where 'life0: 'async_trait, Self: 'async_trait,
The 
textDocument/rangeFormatting request is sent from the client to the server to
format a given range in a document.source§fn on_type_formatting<'life0, 'async_trait>(
    &'life0 self,
    params: DocumentOnTypeFormattingParams
) -> Pin<Box<dyn Future<Output = Result<Option<Vec<TextEdit>>, Error>> + Send + 'async_trait>>where
    'life0: 'async_trait,
    Self: 'async_trait,
 
fn on_type_formatting<'life0, 'async_trait>( &'life0 self, params: DocumentOnTypeFormattingParams ) -> Pin<Box<dyn Future<Output = Result<Option<Vec<TextEdit>>, Error>> + Send + 'async_trait>>where 'life0: 'async_trait, Self: 'async_trait,
The 
textDocument/onTypeFormatting request is sent from the client to the server to
format parts of the document during typing.source§fn prepare_rename<'life0, 'async_trait>(
    &'life0 self,
    params: TextDocumentPositionParams
) -> Pin<Box<dyn Future<Output = Result<Option<PrepareRenameResponse>, Error>> + Send + 'async_trait>>where
    'life0: 'async_trait,
    Self: 'async_trait,
 
fn prepare_rename<'life0, 'async_trait>( &'life0 self, params: TextDocumentPositionParams ) -> Pin<Box<dyn Future<Output = Result<Option<PrepareRenameResponse>, Error>> + Send + 'async_trait>>where 'life0: 'async_trait, Self: 'async_trait,
The 
textDocument/prepareRename request is sent from the client to the server to setup
and test the validity of a rename operation at a given location. Read moresource§fn linked_editing_range<'life0, 'async_trait>(
    &'life0 self,
    params: LinkedEditingRangeParams
) -> Pin<Box<dyn Future<Output = Result<Option<LinkedEditingRanges>, Error>> + Send + 'async_trait>>where
    'life0: 'async_trait,
    Self: 'async_trait,
 
fn linked_editing_range<'life0, 'async_trait>( &'life0 self, params: LinkedEditingRangeParams ) -> Pin<Box<dyn Future<Output = Result<Option<LinkedEditingRanges>, Error>> + Send + 'async_trait>>where 'life0: 'async_trait, Self: 'async_trait,
The 
textDocument/linkedEditingRange request is sent from the client to the server to
return for a given position in a document the range of the symbol at the position and all
ranges that have the same content. Read moresource§fn symbol<'life0, 'async_trait>(
    &'life0 self,
    params: WorkspaceSymbolParams
) -> Pin<Box<dyn Future<Output = Result<Option<Vec<SymbolInformation>>, Error>> + Send + 'async_trait>>where
    'life0: 'async_trait,
    Self: 'async_trait,
 
fn symbol<'life0, 'async_trait>( &'life0 self, params: WorkspaceSymbolParams ) -> Pin<Box<dyn Future<Output = Result<Option<Vec<SymbolInformation>>, Error>> + Send + 'async_trait>>where 'life0: 'async_trait, Self: 'async_trait,
The 
workspace/symbol request is sent from the client to the server to list project-wide
symbols matching the given query string. Read moresource§fn symbol_resolve<'life0, 'async_trait>(
    &'life0 self,
    params: WorkspaceSymbol
) -> Pin<Box<dyn Future<Output = Result<WorkspaceSymbol, Error>> + Send + 'async_trait>>where
    'life0: 'async_trait,
    Self: 'async_trait,
 
fn symbol_resolve<'life0, 'async_trait>( &'life0 self, params: WorkspaceSymbol ) -> Pin<Box<dyn Future<Output = Result<WorkspaceSymbol, Error>> + Send + 'async_trait>>where 'life0: 'async_trait, Self: 'async_trait,
The 
workspaceSymbol/resolve request is sent from the client to the server to resolve
additional information for a given workspace symbol. Read moresource§fn will_create_files<'life0, 'async_trait>(
    &'life0 self,
    params: CreateFilesParams
) -> Pin<Box<dyn Future<Output = Result<Option<WorkspaceEdit>, Error>> + Send + 'async_trait>>where
    'life0: 'async_trait,
    Self: 'async_trait,
 
fn will_create_files<'life0, 'async_trait>( &'life0 self, params: CreateFilesParams ) -> Pin<Box<dyn Future<Output = Result<Option<WorkspaceEdit>, Error>> + Send + 'async_trait>>where 'life0: 'async_trait, Self: 'async_trait,
The 
workspace/willCreateFiles request is sent from the client to the server before
files are actually created as long as the creation is triggered from within the client. Read moresource§fn did_create_files<'life0, 'async_trait>(
    &'life0 self,
    params: CreateFilesParams
) -> Pin<Box<dyn Future<Output = ()> + Send + 'async_trait>>where
    'life0: 'async_trait,
    Self: 'async_trait,
 
fn did_create_files<'life0, 'async_trait>( &'life0 self, params: CreateFilesParams ) -> Pin<Box<dyn Future<Output = ()> + Send + 'async_trait>>where 'life0: 'async_trait, Self: 'async_trait,
The 
workspace/didCreateFiles request is sent from the client to the server when files
were created from within the client.source§fn will_rename_files<'life0, 'async_trait>(
    &'life0 self,
    params: RenameFilesParams
) -> Pin<Box<dyn Future<Output = Result<Option<WorkspaceEdit>, Error>> + Send + 'async_trait>>where
    'life0: 'async_trait,
    Self: 'async_trait,
 
fn will_rename_files<'life0, 'async_trait>( &'life0 self, params: RenameFilesParams ) -> Pin<Box<dyn Future<Output = Result<Option<WorkspaceEdit>, Error>> + Send + 'async_trait>>where 'life0: 'async_trait, Self: 'async_trait,
The 
workspace/willRenameFiles request is sent from the client to the server before
files are actually renamed as long as the rename is triggered from within the client. Read moresource§fn did_rename_files<'life0, 'async_trait>(
    &'life0 self,
    params: RenameFilesParams
) -> Pin<Box<dyn Future<Output = ()> + Send + 'async_trait>>where
    'life0: 'async_trait,
    Self: 'async_trait,
 
fn did_rename_files<'life0, 'async_trait>( &'life0 self, params: RenameFilesParams ) -> Pin<Box<dyn Future<Output = ()> + Send + 'async_trait>>where 'life0: 'async_trait, Self: 'async_trait,
The 
workspace/didRenameFiles notification is sent from the client to the server when
files were renamed from within the client.source§fn will_delete_files<'life0, 'async_trait>(
    &'life0 self,
    params: DeleteFilesParams
) -> Pin<Box<dyn Future<Output = Result<Option<WorkspaceEdit>, Error>> + Send + 'async_trait>>where
    'life0: 'async_trait,
    Self: 'async_trait,
 
fn will_delete_files<'life0, 'async_trait>( &'life0 self, params: DeleteFilesParams ) -> Pin<Box<dyn Future<Output = Result<Option<WorkspaceEdit>, Error>> + Send + 'async_trait>>where 'life0: 'async_trait, Self: 'async_trait,
The 
workspace/willDeleteFiles request is sent from the client to the server before
files are actually deleted as long as the deletion is triggered from within the client
either by a user action or by applying a workspace edit. Read moresource§fn did_delete_files<'life0, 'async_trait>(
    &'life0 self,
    params: DeleteFilesParams
) -> Pin<Box<dyn Future<Output = ()> + Send + 'async_trait>>where
    'life0: 'async_trait,
    Self: 'async_trait,
 
fn did_delete_files<'life0, 'async_trait>( &'life0 self, params: DeleteFilesParams ) -> Pin<Box<dyn Future<Output = ()> + Send + 'async_trait>>where 'life0: 'async_trait, Self: 'async_trait,
The 
workspace/didDeleteFiles notification is sent from the client to the server when
files were deleted from within the client.source§fn execute_command<'life0, 'async_trait>(
    &'life0 self,
    params: ExecuteCommandParams
) -> Pin<Box<dyn Future<Output = Result<Option<Value>, Error>> + Send + 'async_trait>>where
    'life0: 'async_trait,
    Self: 'async_trait,
 
fn execute_command<'life0, 'async_trait>( &'life0 self, params: ExecuteCommandParams ) -> Pin<Box<dyn Future<Output = Result<Option<Value>, Error>> + Send + 'async_trait>>where 'life0: 'async_trait, Self: 'async_trait,
The 
workspace/executeCommand request is sent from the client to the server to trigger
command execution on the server. Read moreAuto Trait Implementations§
impl !RefUnwindSafe for Backend
impl Send for Backend
impl Sync for Backend
impl Unpin for Backend
impl !UnwindSafe for Backend
Blanket Implementations§
source§impl<T> BorrowMut<T> for Twhere
    T: ?Sized,
 
impl<T> BorrowMut<T> for Twhere T: ?Sized,
source§fn borrow_mut(&mut self) -> &mut T
 
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
§impl<T> Conv for T
 
impl<T> Conv for T
§impl<T> FmtForward for T
 
impl<T> FmtForward for T
§fn fmt_binary(self) -> FmtBinary<Self>where
    Self: Binary,
 
fn fmt_binary(self) -> FmtBinary<Self>where Self: Binary,
Causes 
self to use its Binary implementation when Debug-formatted.§fn fmt_display(self) -> FmtDisplay<Self>where
    Self: Display,
 
fn fmt_display(self) -> FmtDisplay<Self>where Self: Display,
Causes 
self to use its Display implementation when
Debug-formatted.§fn fmt_lower_exp(self) -> FmtLowerExp<Self>where
    Self: LowerExp,
 
fn fmt_lower_exp(self) -> FmtLowerExp<Self>where Self: LowerExp,
Causes 
self to use its LowerExp implementation when
Debug-formatted.§fn fmt_lower_hex(self) -> FmtLowerHex<Self>where
    Self: LowerHex,
 
fn fmt_lower_hex(self) -> FmtLowerHex<Self>where Self: LowerHex,
Causes 
self to use its LowerHex implementation when
Debug-formatted.§fn fmt_octal(self) -> FmtOctal<Self>where
    Self: Octal,
 
fn fmt_octal(self) -> FmtOctal<Self>where Self: Octal,
Causes 
self to use its Octal implementation when Debug-formatted.§fn fmt_pointer(self) -> FmtPointer<Self>where
    Self: Pointer,
 
fn fmt_pointer(self) -> FmtPointer<Self>where Self: Pointer,
Causes 
self to use its Pointer implementation when
Debug-formatted.§fn fmt_upper_exp(self) -> FmtUpperExp<Self>where
    Self: UpperExp,
 
fn fmt_upper_exp(self) -> FmtUpperExp<Self>where Self: UpperExp,
Causes 
self to use its UpperExp implementation when
Debug-formatted.§fn fmt_upper_hex(self) -> FmtUpperHex<Self>where
    Self: UpperHex,
 
fn fmt_upper_hex(self) -> FmtUpperHex<Self>where Self: UpperHex,
Causes 
self to use its UpperHex implementation when
Debug-formatted.§fn fmt_list(self) -> FmtList<Self>where
    &'a Self: for<'a> IntoIterator,
 
fn fmt_list(self) -> FmtList<Self>where &'a Self: for<'a> IntoIterator,
Formats each item in a sequence. Read more
§impl<T> Instrument for T
 
impl<T> Instrument for T
§fn instrument(self, span: Span) -> Instrumented<Self>
 
fn instrument(self, span: Span) -> Instrumented<Self>
§fn in_current_span(self) -> Instrumented<Self>
 
fn in_current_span(self) -> Instrumented<Self>
source§impl<T> IntoResult<T> for T
 
impl<T> IntoResult<T> for T
type Err = Infallible
fn into_result(self) -> Result<T, <T as IntoResult<T>>::Err>
§impl<T> Pipe for Twhere
    T: ?Sized,
 
impl<T> Pipe for Twhere T: ?Sized,
§fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> Rwhere
    Self: Sized,
 
fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> Rwhere Self: Sized,
Pipes by value. This is generally the method you want to use. Read more
§fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> Rwhere
    R: 'a,
 
fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> Rwhere R: 'a,
Borrows 
self and passes that borrow into the pipe function. Read more§fn pipe_ref_mut<'a, R>(&'a mut self, func: impl FnOnce(&'a mut Self) -> R) -> Rwhere
    R: 'a,
 
fn pipe_ref_mut<'a, R>(&'a mut self, func: impl FnOnce(&'a mut Self) -> R) -> Rwhere R: 'a,
Mutably borrows 
self and passes that borrow into the pipe function. Read more§fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> Rwhere
    Self: Borrow<B>,
    B: 'a + ?Sized,
    R: 'a,
 
fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> Rwhere Self: Borrow<B>, B: 'a + ?Sized, R: 'a,
§fn pipe_borrow_mut<'a, B, R>(
    &'a mut self,
    func: impl FnOnce(&'a mut B) -> R
) -> Rwhere
    Self: BorrowMut<B>,
    B: 'a + ?Sized,
    R: 'a,
 
fn pipe_borrow_mut<'a, B, R>( &'a mut self, func: impl FnOnce(&'a mut B) -> R ) -> Rwhere Self: BorrowMut<B>, B: 'a + ?Sized, R: 'a,
§fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> Rwhere
    Self: AsRef<U>,
    U: 'a + ?Sized,
    R: 'a,
 
fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> Rwhere Self: AsRef<U>, U: 'a + ?Sized, R: 'a,
Borrows 
self, then passes self.as_ref() into the pipe function.§fn pipe_as_mut<'a, U, R>(&'a mut self, func: impl FnOnce(&'a mut U) -> R) -> Rwhere
    Self: AsMut<U>,
    U: 'a + ?Sized,
    R: 'a,
 
fn pipe_as_mut<'a, U, R>(&'a mut self, func: impl FnOnce(&'a mut U) -> R) -> Rwhere Self: AsMut<U>, U: 'a + ?Sized, R: 'a,
Mutably borrows 
self, then passes self.as_mut() into the pipe
function.§impl<T> Tap for T
 
impl<T> Tap for T
§fn tap_borrow<B>(self, func: impl FnOnce(&B)) -> Selfwhere
    Self: Borrow<B>,
    B: ?Sized,
 
fn tap_borrow<B>(self, func: impl FnOnce(&B)) -> Selfwhere Self: Borrow<B>, B: ?Sized,
Immutable access to the 
Borrow<B> of a value. Read more§fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Selfwhere
    Self: BorrowMut<B>,
    B: ?Sized,
 
fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Selfwhere Self: BorrowMut<B>, B: ?Sized,
Mutable access to the 
BorrowMut<B> of a value. Read more§fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Selfwhere
    Self: AsRef<R>,
    R: ?Sized,
 
fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Selfwhere Self: AsRef<R>, R: ?Sized,
Immutable access to the 
AsRef<R> view of a value. Read more§fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Selfwhere
    Self: AsMut<R>,
    R: ?Sized,
 
fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Selfwhere Self: AsMut<R>, R: ?Sized,
Mutable access to the 
AsMut<R> view of a value. Read more§fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Selfwhere
    Self: Deref<Target = T>,
    T: ?Sized,
 
fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Selfwhere Self: Deref<Target = T>, T: ?Sized,
Immutable access to the 
Deref::Target of a value. Read more§fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Selfwhere
    Self: DerefMut<Target = T> + Deref,
    T: ?Sized,
 
fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Selfwhere Self: DerefMut<Target = T> + Deref, T: ?Sized,
Mutable access to the 
Deref::Target of a value. Read more§fn tap_dbg(self, func: impl FnOnce(&Self)) -> Self
 
fn tap_dbg(self, func: impl FnOnce(&Self)) -> Self
Calls 
.tap() only in debug builds, and is erased in release builds.§fn tap_mut_dbg(self, func: impl FnOnce(&mut Self)) -> Self
 
fn tap_mut_dbg(self, func: impl FnOnce(&mut Self)) -> Self
Calls 
.tap_mut() only in debug builds, and is erased in release
builds.§fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Selfwhere
    Self: Borrow<B>,
    B: ?Sized,
 
fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Selfwhere Self: Borrow<B>, B: ?Sized,
Calls 
.tap_borrow() only in debug builds, and is erased in release
builds.§fn tap_borrow_mut_dbg<B>(self, func: impl FnOnce(&mut B)) -> Selfwhere
    Self: BorrowMut<B>,
    B: ?Sized,
 
fn tap_borrow_mut_dbg<B>(self, func: impl FnOnce(&mut B)) -> Selfwhere Self: BorrowMut<B>, B: ?Sized,
Calls 
.tap_borrow_mut() only in debug builds, and is erased in release
builds.§fn tap_ref_dbg<R>(self, func: impl FnOnce(&R)) -> Selfwhere
    Self: AsRef<R>,
    R: ?Sized,
 
fn tap_ref_dbg<R>(self, func: impl FnOnce(&R)) -> Selfwhere Self: AsRef<R>, R: ?Sized,
Calls 
.tap_ref() only in debug builds, and is erased in release
builds.§fn tap_ref_mut_dbg<R>(self, func: impl FnOnce(&mut R)) -> Selfwhere
    Self: AsMut<R>,
    R: ?Sized,
 
fn tap_ref_mut_dbg<R>(self, func: impl FnOnce(&mut R)) -> Selfwhere Self: AsMut<R>, R: ?Sized,
Calls 
.tap_ref_mut() only in debug builds, and is erased in release
builds.