Defines most of the 'Basic Structures' in the LSP specification (https://microsoft.github.io/language-server-protocol/specifications/specification-current/), as well as some utilities.
Since LSP is Json-based, Ints/Nats are represented by Floats on the wire.
Equations
Equations
- Lean.Lsp.instToJsonLocation = { toJson := Lean.Lsp.toJsonLocation✝ }
Equations
- Lean.Lsp.instFromJsonLocation = { fromJson? := Lean.Lsp.fromJsonLocation✝ }
Equations
- Lean.Lsp.instOrdLocation = { compare := Lean.Lsp.ordLocation✝ }
- targetUri : DocumentUri
- targetRange : Range
- targetSelectionRange : Range
Instances For
Equations
Equations
- Lean.Lsp.instFromJsonLocationLink = { fromJson? := Lean.Lsp.fromJsonLocationLink✝ }
Represents a reference to a client editor command.
NOTE: No specific commands are specified by LSP, hence possible commands need to be announced as capabilities.
- title : StringTitle of the command, like save.
- command : StringThe identifier of the actual command handler. 
- Arguments that the command handler should be invoked with. 
Instances For
Equations
- Lean.Lsp.instToJsonCommand = { toJson := Lean.Lsp.toJsonCommand✝ }
Equations
- Lean.Lsp.instFromJsonCommand = { fromJson? := Lean.Lsp.fromJsonCommand✝ }
A snippet is a string that gets inserted into a document, and can afterwards be edited by the user in a structured way.
Snippets contain instructions that specify how this structured editing should proceed. They are expressed in a domain-specific language based on one from TextMate, including the following constructs:
- Designated positions for subsequent user input,
called "tab stops" after their most frequently-used keybinding.
They are denoted with $1,$2, and so forth.$0denotes where the cursor should be positioned after all edits are completed, defaulting to the end of the string. Snippet tab stops are unrelated to tab stops used for indentation.
- Tab stops with default values, called placeholders, written ${1:default}. The default may itself contain a tab stop or a further placeholder and multiple options to select from may be provided by surrounding them with|s and separating them with,, as in${1|if $2 then $3 else $4,if let $2 := $3 then $4 else $5|}.
- One of a set of predefined variables that are replaced with their values.
This includes the current line number ($TM_LINE_NUMBER) or the text that was selected when the snippet was invoked ($TM_SELECTED_TEXT).
- Formatting instructions to modify variables using regular expressions or a set of predefined filters.
The full syntax and semantics of snippets, including the available variables and the rules for escaping control characters, are described in the LSP specification.
- value : String
Instances For
Equations
Equations
- Lean.Lsp.instFromJsonSnippetString = { fromJson? := Lean.Lsp.fromJsonSnippetString✝ }
A textual edit applicable to a text document.
- range : RangeThe range of the text document to be manipulated. To insert text into a document create a range where start = end.
- newText : StringThe string to be inserted. For delete operations use an empty string. 
- leanExtSnippet? : Option SnippetStringIf this field is present and the editor supports it, newTextis ignored and an interactive snippet edit is performed instead.The use of snippets in TextEdits is a Lean-specific extension to the LSP standard, sonewTextshould still be set to a correct value as fallback in case the editor does not support this feature. Even editors that support snippets may not always use them; for instance, if the file is not already open, VS Code will perform a normal text edit in the background instead.
- Identifier for annotated edit. - WorkspaceEdithas a- changeAnnotationsfield that maps these identifiers to a- ChangeAnnotation. By annotating an edit you can add a description of what the edit will do and also control whether the user is presented with a prompt before applying the edit. reference.
Instances For
Equations
- Lean.Lsp.instToJsonTextEdit = { toJson := Lean.Lsp.toJsonTextEdit✝ }
Equations
- Lean.Lsp.instFromJsonTextEdit = { fromJson? := Lean.Lsp.fromJsonTextEdit✝ }
Equations
- Lean.Lsp.instFromJsonTextEditBatch = { fromJson? := Lean.fromJson? }
Equations
- Lean.Lsp.instToJsonTextEditBatch = { toJson := Lean.toJson }
Equations
- Lean.Lsp.instCoeTextEditTextEditBatch = { coe := fun (te : Lean.Lsp.TextEdit) => #[te] }
- uri : DocumentUri
Instances For
A batch of TextEdits to perform on a versioned text document.
- textDocument : VersionedTextDocumentIdentifier
- edits : TextEditBatch
Instances For
Equations
Equations
Additional information that describes document changes.
- label : StringA human-readable string describing the actual change. The string is rendered prominent in the user interface. 
- needsConfirmation : BoolA flag which indicates that user confirmation is needed before applying the change. 
- A human-readable string which is rendered less prominent in the user interface. 
Instances For
Equations
Equations
Options for CreateFile and RenameFile.
Instances For
Equations
Equations
Options for DeleteFile.
Instances For
Equations
Equations
- uri : DocumentUri
Instances For
Equations
Equations
- Lean.Lsp.instFromJsonCreateFile = { fromJson? := Lean.Lsp.fromJsonCreateFile✝ }
- oldUri : DocumentUri
- newUri : DocumentUri
- options? : Option CreateFile.Options
Instances For
Equations
Equations
- Lean.Lsp.instFromJsonRenameFile = { fromJson? := Lean.Lsp.fromJsonRenameFile✝ }
- uri : DocumentUri
Instances For
Equations
Equations
- Lean.Lsp.instFromJsonDeleteFile = { fromJson? := Lean.Lsp.fromJsonDeleteFile✝ }
A change to a file resource.
- create : CreateFile → DocumentChange
- rename : RenameFile → DocumentChange
- delete : DeleteFile → DocumentChange
- edit : TextDocumentEdit → DocumentChange
Instances For
Equations
- One or more equations did not get rendered due to their size.
Equations
- One or more equations did not get rendered due to their size.
A workspace edit represents changes to many resources managed in the workspace.
- changes? : Option (Std.TreeMap DocumentUri TextEditBatch compare)Changes to existing resources. 
- documentChanges? : Option (Array DocumentChange)Depending on the client capability workspace.workspaceEdit.resourceOperationsdocument changes are either an array ofTextDocumentEdits to express changes to n different text documents where each text document edit addresses a specific version of a text document. Or it can contain aboveTextDocumentEdits mixed with create, rename and delete file / folder operations.Whether a client supports versioned document edits is expressed via workspace.workspaceEdit.documentChangesclient capability.If a client neither supports documentChangesnorworkspace.workspaceEdit.resourceOperationsthen only plainTextEdits using thechangesproperty are supported.
- changeAnnotations? : Option (Std.TreeMap String ChangeAnnotation compare)A map of change annotations that can be referenced in AnnotatedTextEdits or create, rename and delete file / folder operations.Whether clients honor this property depends on the client capability workspace.changeAnnotationSupport.
Instances For
Equations
Equations
- Lean.Lsp.instFromJsonWorkspaceEdit = { fromJson? := Lean.Lsp.fromJsonWorkspaceEdit✝ }
Equations
- One or more equations did not get rendered due to their size.
Equations
- Lean.Lsp.WorkspaceEdit.ofTextDocumentEdit e = { documentChanges? := some #[Lean.Lsp.DocumentChange.edit e] }
Instances For
Equations
- Lean.Lsp.WorkspaceEdit.ofTextEdit doc te = Lean.Lsp.WorkspaceEdit.ofTextDocumentEdit { textDocument := doc, edits := #[te] }
Instances For
The workspace/applyEdit request is sent from the server to the client to modify resource on the client side.
- An optional label of the workspace edit. This label is presented in the user interface for example on an undo stack to undo the workspace edit. 
- edit : WorkspaceEditThe edits to apply. 
Instances For
An item to transfer a text document from the client to the server.
- uri : DocumentUriThe text document's URI. 
- languageId : StringThe text document's language identifier. 
- version : NatThe version number of this document (it will increase after each change, including undo/redo). 
- text : StringThe content of the opened text document. 
Instances For
Equations
Equations
- textDocument : TextDocumentIdentifier
- position : Position
Instances For
Equations
- One or more equations did not get rendered due to their size.
Equations
Equations
Instances For
Equations
- Lean.Lsp.instFromJsonDocumentSelector = { fromJson? := Lean.fromJson? }
Equations
- Lean.Lsp.instToJsonDocumentSelector = { toJson := Lean.toJson }
- documentSelector? : Option DocumentSelector
Instances For
Equations
Equations
- One or more equations did not get rendered due to their size.
Equations
- One or more equations did not get rendered due to their size.
Equations
Equations
- Lean.Lsp.instFromJsonMarkupContent = { fromJson? := Lean.Lsp.fromJsonMarkupContent✝ }
Equations
Reference to the progress of some in-flight piece of work.
Equations
Instances For
Equations
- workDoneToken? : Option ProgressToken
Instances For
- partialResultToken? : Option ProgressToken