; | |
Object.defineProperty(exports, "__esModule", { value: true }); | |
exports.SignatureHelpTriggerKind = exports.InsertTextMode = exports.InsertTextFormat = exports.CodeActionKind = exports.TextDocumentSyncKind = exports.CompletionTriggerKind = exports.LanguageIdentifier = exports.CompletionItemKind = exports.CompletionItemTag = exports.MarkupKind = void 0; | |
/** | |
* Describes the content type that a client supports in various | |
* result literals like `Hover`, `ParameterInfo` or `CompletionItem`. | |
* | |
* Please note that `MarkupKinds` must not start with a `$`. This kinds | |
* are reserved for internal usage. | |
*/ | |
var MarkupKind; | |
(function (MarkupKind) { | |
/** | |
* Plain text is supported as a content format | |
*/ | |
MarkupKind["PlainText"] = "plaintext"; | |
/** | |
* Markdown is supported as a content format | |
*/ | |
MarkupKind["Markdown"] = "markdown"; | |
})(MarkupKind || (exports.MarkupKind = MarkupKind = {})); | |
/** | |
* Completion item tags are extra annotations that tweak the rendering of | |
* a completion item. | |
* | |
* @since 3.15.0 | |
*/ | |
var CompletionItemTag; | |
(function (CompletionItemTag) { | |
/** | |
* Render a completion as obsolete, usually using a strike-out. | |
*/ | |
CompletionItemTag[CompletionItemTag["Deprecated"] = 1] = "Deprecated"; | |
})(CompletionItemTag || (exports.CompletionItemTag = CompletionItemTag = {})); | |
/** | |
* The kind of a completion entry. | |
*/ | |
var CompletionItemKind; | |
(function (CompletionItemKind) { | |
CompletionItemKind[CompletionItemKind["Text"] = 1] = "Text"; | |
CompletionItemKind[CompletionItemKind["Method"] = 2] = "Method"; | |
CompletionItemKind[CompletionItemKind["Function"] = 3] = "Function"; | |
CompletionItemKind[CompletionItemKind["Constructor"] = 4] = "Constructor"; | |
CompletionItemKind[CompletionItemKind["Field"] = 5] = "Field"; | |
CompletionItemKind[CompletionItemKind["Variable"] = 6] = "Variable"; | |
CompletionItemKind[CompletionItemKind["Class"] = 7] = "Class"; | |
CompletionItemKind[CompletionItemKind["Interface"] = 8] = "Interface"; | |
CompletionItemKind[CompletionItemKind["Module"] = 9] = "Module"; | |
CompletionItemKind[CompletionItemKind["Property"] = 10] = "Property"; | |
CompletionItemKind[CompletionItemKind["Unit"] = 11] = "Unit"; | |
CompletionItemKind[CompletionItemKind["Value"] = 12] = "Value"; | |
CompletionItemKind[CompletionItemKind["Enum"] = 13] = "Enum"; | |
CompletionItemKind[CompletionItemKind["Keyword"] = 14] = "Keyword"; | |
CompletionItemKind[CompletionItemKind["Snippet"] = 15] = "Snippet"; | |
CompletionItemKind[CompletionItemKind["Color"] = 16] = "Color"; | |
CompletionItemKind[CompletionItemKind["File"] = 17] = "File"; | |
CompletionItemKind[CompletionItemKind["Reference"] = 18] = "Reference"; | |
CompletionItemKind[CompletionItemKind["Folder"] = 19] = "Folder"; | |
CompletionItemKind[CompletionItemKind["EnumMember"] = 20] = "EnumMember"; | |
CompletionItemKind[CompletionItemKind["Constant"] = 21] = "Constant"; | |
CompletionItemKind[CompletionItemKind["Struct"] = 22] = "Struct"; | |
CompletionItemKind[CompletionItemKind["Event"] = 23] = "Event"; | |
CompletionItemKind[CompletionItemKind["Operator"] = 24] = "Operator"; | |
CompletionItemKind[CompletionItemKind["TypeParameter"] = 25] = "TypeParameter"; | |
})(CompletionItemKind || (exports.CompletionItemKind = CompletionItemKind = {})); | |
/** | |
* Known language identifiers. | |
* https://microsoft.github.io/language-server-protocol/specifications/specification-current/#textDocumentItem | |
*/ | |
var LanguageIdentifier; | |
(function (LanguageIdentifier) { | |
LanguageIdentifier["ABAP"] = "abap"; | |
LanguageIdentifier["WindowsBat"] = "bat"; | |
LanguageIdentifier["BibTeX"] = "bibtex"; | |
LanguageIdentifier["Clojure"] = "clojure"; | |
LanguageIdentifier["Coffeescript"] = "coffeescript"; | |
LanguageIdentifier["C"] = "c"; | |
LanguageIdentifier["CPlusPlus"] = "cpp"; | |
LanguageIdentifier["CSharp"] = "csharp"; | |
LanguageIdentifier["CSS"] = "css"; | |
LanguageIdentifier["Diff"] = "diff"; | |
LanguageIdentifier["Dart"] = "dart"; | |
LanguageIdentifier["Dockerfile"] = "dockerfile"; | |
LanguageIdentifier["Elixir"] = "elixir"; | |
LanguageIdentifier["Erlang"] = "erlang"; | |
LanguageIdentifier["FSharp"] = "fsharp"; | |
LanguageIdentifier["GitCommit"] = "git-commit"; | |
LanguageIdentifier["GitRebase"] = "git-rebase"; | |
LanguageIdentifier["Go"] = "go"; | |
LanguageIdentifier["Groovy"] = "groovy"; | |
LanguageIdentifier["Handlebars"] = "handlebars"; | |
LanguageIdentifier["HTML"] = "html"; | |
LanguageIdentifier["Ini"] = "ini"; | |
LanguageIdentifier["Java"] = "java"; | |
LanguageIdentifier["JavaScript"] = "javascript"; | |
LanguageIdentifier["JavaScriptReact"] = "javascriptreact"; | |
LanguageIdentifier["JSON"] = "json"; | |
LanguageIdentifier["LaTeX"] = "latex"; | |
LanguageIdentifier["Less"] = "less"; | |
LanguageIdentifier["Lua"] = "lua"; | |
LanguageIdentifier["Makefile"] = "makefile"; | |
LanguageIdentifier["Markdown"] = "markdown"; | |
LanguageIdentifier["ObjectiveC"] = "c"; | |
LanguageIdentifier["ObjectiveCPlusPlus"] = "cpp"; | |
LanguageIdentifier["Perl"] = "perl"; | |
LanguageIdentifier["Perl6"] = "perl6"; | |
LanguageIdentifier["PHP"] = "php"; | |
LanguageIdentifier["Powershell"] = "powershell"; | |
LanguageIdentifier["Pug"] = "jade"; | |
LanguageIdentifier["Python"] = "python"; | |
LanguageIdentifier["R"] = "r"; | |
LanguageIdentifier["Razor"] = "razor"; | |
LanguageIdentifier["Ruby"] = "ruby"; | |
LanguageIdentifier["Rust"] = "rust"; | |
LanguageIdentifier["SCSS"] = "scss"; | |
LanguageIdentifier["Sass"] = "syntax"; | |
LanguageIdentifier["Scala"] = "scala"; | |
LanguageIdentifier["ShaderLab"] = "shaderlab"; | |
LanguageIdentifier["Shell"] = "shellscript"; | |
LanguageIdentifier["SQL"] = "sql"; | |
LanguageIdentifier["Swift"] = "swift"; | |
LanguageIdentifier["TypeScript"] = "typescript"; | |
LanguageIdentifier["TypeScriptReact"] = "typescriptreact"; | |
LanguageIdentifier["TeX"] = "tex"; | |
LanguageIdentifier["VisualBasic"] = "vb"; | |
LanguageIdentifier["XML"] = "xml"; | |
LanguageIdentifier["XSL"] = "xsl"; | |
LanguageIdentifier["YAML"] = "yaml"; | |
})(LanguageIdentifier || (exports.LanguageIdentifier = LanguageIdentifier = {})); | |
/** | |
* How a completion was triggered | |
* https://microsoft.github.io/language-server-protocol/specifications/specification-current/#textDocument_completion | |
*/ | |
var CompletionTriggerKind; | |
(function (CompletionTriggerKind) { | |
/** | |
* Completion was triggered by typing an identifier (24x7 code | |
* complete), manual invocation (e.g Ctrl+Space) or via API. | |
*/ | |
CompletionTriggerKind[CompletionTriggerKind["Invoked"] = 1] = "Invoked"; | |
/** | |
* Completion was triggered by a trigger character specified by | |
* the `triggerCharacters` properties of the | |
* `CompletionRegistrationOptions`. | |
*/ | |
CompletionTriggerKind[CompletionTriggerKind["TriggerCharacter"] = 2] = "TriggerCharacter"; | |
/** | |
* Completion was re-triggered as the current completion list is incomplete. | |
*/ | |
CompletionTriggerKind[CompletionTriggerKind["TriggerForIncompleteCompletions"] = 3] = "TriggerForIncompleteCompletions"; | |
})(CompletionTriggerKind || (exports.CompletionTriggerKind = CompletionTriggerKind = {})); | |
/** | |
* Defines how the host (editor) should sync document changes | |
* to the language server. | |
*/ | |
var TextDocumentSyncKind; | |
(function (TextDocumentSyncKind) { | |
/** | |
* Documents should not be synced at all. | |
*/ | |
TextDocumentSyncKind[TextDocumentSyncKind["None"] = 0] = "None"; | |
/** | |
* Documents are synced by always sending the full content | |
* of the document. | |
*/ | |
TextDocumentSyncKind[TextDocumentSyncKind["Full"] = 1] = "Full"; | |
/** | |
* Documents are synced by sending the full content on open. | |
* After that only incremental updates to the document are | |
* send. | |
*/ | |
TextDocumentSyncKind[TextDocumentSyncKind["Incremental"] = 2] = "Incremental"; | |
})(TextDocumentSyncKind || (exports.TextDocumentSyncKind = TextDocumentSyncKind = {})); | |
/** | |
* The kind of a code action. | |
* | |
* Kinds are a hierarchical list of identifiers separated by `.`, | |
* e.g. `"refactor.extract.function"`. | |
* | |
* The set of kinds is open and the client needs to announce the kinds it | |
* supports to the server during initialization. | |
*/ | |
var CodeActionKind; | |
(function (CodeActionKind) { | |
/** | |
* Empty kind. | |
*/ | |
CodeActionKind["Empty"] = ""; | |
/** | |
* Base kind for quickfix actions: 'quickfix'. | |
*/ | |
CodeActionKind["QuickFix"] = "quickfix"; | |
/** | |
* Base kind for refactoring actions: 'refactor'. | |
*/ | |
CodeActionKind["Refactor"] = "refactor"; | |
/** | |
* Base kind for refactoring extraction actions: 'refactor.extract'. | |
* | |
* Example extract actions: | |
* | |
* - Extract method | |
* - Extract function | |
* - Extract variable | |
* - Extract interface from class | |
* - ... | |
*/ | |
CodeActionKind["RefactorExtract"] = "refactor.extract"; | |
/** | |
* Base kind for refactoring inline actions: 'refactor.inline'. | |
* | |
* Example inline actions: | |
* | |
* - Inline function | |
* - Inline variable | |
* - Inline constant | |
* - ... | |
*/ | |
CodeActionKind["RefactorInline"] = "refactor.inline"; | |
/** | |
* Base kind for refactoring rewrite actions: 'refactor.rewrite'. | |
* | |
* Example rewrite actions: | |
* | |
* - Convert JavaScript function to class | |
* - Add or remove parameter | |
* - Encapsulate field | |
* - Make method static | |
* - Move method to base class | |
* - ... | |
*/ | |
CodeActionKind["RefactorRewrite"] = "refactor.rewrite"; | |
/** | |
* Base kind for source actions: `source`. | |
* | |
* Source code actions apply to the entire file. | |
*/ | |
CodeActionKind["Source"] = "source"; | |
/** | |
* Base kind for an organize imports source action `source.organizeImports`. | |
*/ | |
CodeActionKind["SourceOrganizeImports"] = "source.organizeImports"; | |
})(CodeActionKind || (exports.CodeActionKind = CodeActionKind = {})); | |
/** | |
* Defines whether the insert text in a completion item should be interpreted as | |
* plain text or a snippet. | |
*/ | |
var InsertTextFormat; | |
(function (InsertTextFormat) { | |
/** | |
* The primary text to be inserted is treated as a plain string. | |
*/ | |
InsertTextFormat[InsertTextFormat["PlainText"] = 1] = "PlainText"; | |
/** | |
* The primary text to be inserted is treated as a snippet. | |
* | |
* A snippet can define tab stops and placeholders with `$1`, `$2` | |
* and `${3:foo}`. `$0` defines the final tab stop, it defaults to | |
* the end of the snippet. Placeholders with equal identifiers are linked, | |
* that is typing in one will update others too. | |
*/ | |
InsertTextFormat[InsertTextFormat["Snippet"] = 2] = "Snippet"; | |
})(InsertTextFormat || (exports.InsertTextFormat = InsertTextFormat = {})); | |
/** | |
* How whitespace and indentation is handled during completion | |
* item insertion. | |
* | |
* @since 3.16.0 | |
*/ | |
var InsertTextMode; | |
(function (InsertTextMode) { | |
/** | |
* The insertion or replace strings is taken as it is. If the | |
* value is multi line the lines below the cursor will be | |
* inserted using the indentation defined in the string value. | |
* The client will not apply any kind of adjustments to the | |
* string. | |
*/ | |
InsertTextMode[InsertTextMode["asIs"] = 1] = "asIs"; | |
/** | |
* The editor adjusts leading whitespace of new lines so that | |
* they match the indentation up to the cursor of the line for | |
* which the item is accepted. | |
* | |
* Consider a line like this: <2tabs><cursor><3tabs>foo. Accepting a | |
* multi line completion item is indented using 2 tabs and all | |
* following lines inserted will be indented using 2 tabs as well. | |
*/ | |
InsertTextMode[InsertTextMode["adjustIndentation"] = 2] = "adjustIndentation"; | |
})(InsertTextMode || (exports.InsertTextMode = InsertTextMode = {})); | |
/** | |
* How a signature help was triggered. | |
* | |
* @since 3.15.0 | |
*/ | |
var SignatureHelpTriggerKind; | |
(function (SignatureHelpTriggerKind) { | |
/** | |
* Signature help was invoked manually by the user or by a command. | |
*/ | |
SignatureHelpTriggerKind[SignatureHelpTriggerKind["Invoked"] = 1] = "Invoked"; | |
/** | |
* Signature help was triggered by a trigger character. | |
*/ | |
SignatureHelpTriggerKind[SignatureHelpTriggerKind["TriggerCharacter"] = 2] = "TriggerCharacter"; | |
/** | |
* Signature help was triggered by the cursor moving or by the document | |
* content changing. | |
*/ | |
SignatureHelpTriggerKind[SignatureHelpTriggerKind["ContentChange"] = 3] = "ContentChange"; | |
})(SignatureHelpTriggerKind || (exports.SignatureHelpTriggerKind = SignatureHelpTriggerKind = {})); | |
// tslint:enable:enforce-name-casing | |
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"text_document_node.js","sourceRoot":"","sources":["../../../../../../../../genfiles/third_party/colab/sources/lsp/text_document_node.ts"],"names":[],"mappings":"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","sourcesContent":["import * as protocol from './protocol_node';\nimport * as workspace from './workspace_node';\n\n// tslint:disable:enforce-name-casing\n\n/**\n * Text document specific client capabilities.\n */\nexport declare interface TextDocumentClientCapabilities {\n  synchronization?: TextDocumentSyncClientCapabilities;\n\n  /**\n   * Capabilities specific to the `textDocument/completion` request.\n   */\n  completion?: CompletionClientCapabilities;\n\n  /**\n   * Capabilities specific to the `textDocument/hover` request.\n   */\n  hover?: HoverClientCapabilities;\n\n  /**\n   * Capabilities specific to the `textDocument/signatureHelp` request.\n   */\n  signatureHelp?: SignatureHelpClientCapabilities;\n\n  /**\n   * Capabilities specific to the `textDocument/declaration` request.\n   *\n   * @since 3.14.0\n   */\n  declaration?: DeclarationClientCapabilities;\n\n  /**\n   * Capabilities specific to the `textDocument/definition` request.\n   */\n  definition?: DefinitionClientCapabilities;\n\n  /**\n   * Capabilities specific to the `textDocument/typeDefinition` request.\n   *\n   * @since 3.6.0\n   */\n  typeDefinition?: TypeDefinitionClientCapabilities;\n\n  /**\n   * Capabilities specific to the `textDocument/implementation` request.\n   *\n   * @since 3.6.0\n   */\n  implementation?: ImplementationClientCapabilities;\n\n  /**\n   * Capabilities specific to the `textDocument/references` request.\n   */\n  references?: ReferenceClientCapabilities;\n\n  /**\n   * Capabilities specific to the `textDocument/documentHighlight` request.\n   */\n  documentHighlight?: DocumentHighlightClientCapabilities;\n\n  /**\n   * Capabilities specific to the `textDocument/documentSymbol` request.\n   */\n  documentSymbol?: DocumentSymbolClientCapabilities;\n\n  /**\n   * Capabilities specific to the `textDocument/codeAction` request.\n   */\n  codeAction?: CodeActionClientCapabilities;\n\n  /**\n   * Capabilities specific to the `textDocument/codeLens` request.\n   */\n  codeLens?: CodeLensClientCapabilities;\n\n  /**\n   * Capabilities specific to the `textDocument/documentLink` request.\n   */\n  documentLink?: DocumentLinkClientCapabilities;\n\n  /**\n   * Capabilities specific to the `textDocument/documentColor` and the\n   * `textDocument/colorPresentation` request.\n   *\n   * @since 3.6.0\n   */\n  colorProvider?: DocumentColorClientCapabilities;\n\n  /**\n   * Capabilities specific to the `textDocument/formatting` request.\n   */\n  formatting?: DocumentFormattingClientCapabilities;\n\n  /**\n   * Capabilities specific to the `textDocument/rangeFormatting` request.\n   */\n  rangeFormatting?: DocumentRangeFormattingClientCapabilities;\n\n  /**\n   * request.\n   * Capabilities specific to the `textDocument/onTypeFormatting` request.\n   */\n  onTypeFormatting?: DocumentOnTypeFormattingClientCapabilities;\n\n  /**\n   * Capabilities specific to the `textDocument/rename` request.\n   */\n  rename?: RenameClientCapabilities;\n\n  /**\n   * Capabilities specific to the `textDocument/publishDiagnostics`\n   * notification.\n   */\n  publishDiagnostics?: PublishDiagnosticsClientCapabilities;\n\n  /**\n   * Capabilities specific to the `textDocument/foldingRange` request.\n   *\n   * @since 3.10.0\n   */\n  foldingRange?: FoldingRangeClientCapabilities;\n\n  /**\n   * Capabilities specific to the `textDocument/selectionRange` request.\n   *\n   * @since 3.15.0\n   */\n  selectionRange?: SelectionRangeClientCapabilities;\n}\n\n/**\n * https://microsoft.github.io/language-server-protocol/specifications/specification-current/#textDocument_completion\n */\nexport declare interface CompletionClientCapabilities {\n  /**\n   * Whether completion supports dynamic registration.\n   */\n  dynamicRegistration?: boolean;\n\n  /**\n   * The client supports the following `CompletionItem` specific\n   * capabilities.\n   */\n  completionItem?: {\n    /**\n     * Client supports snippets as insert text.\n     *\n     * A snippet can define tab stops and placeholders with `$1`, `$2`\n     * and `${3:foo}`. `$0` defines the final tab stop, it defaults to\n     * the end of the snippet.\n     * Placeholders with equal identifiers are linked, so that typing in\n     * one will update others as well.\n     */\n    snippetSupport?: boolean;\n\n    /**\n     * Client supports commit characters on a completion item.\n     */\n    commitCharactersSupport?: boolean\n\n  /**\n   * Client supports the follow content formats for the documentation\n   * property. The order describes the preferred format of the client.\n   */\n    documentationFormat?: MarkupKind[];\n\n    /**\n     * Client supports the deprecated property on a completion item.\n     */\n    deprecatedSupport?: boolean;\n\n    /**\n     * Client supports the preselect property on a completion item.\n     */\n    preselectSupport?: boolean;\n\n    /**\n     * Client supports the tag property on a completion item.\n     * Clients supporting tags have to handle unknown tags gracefully.\n     * Clients especially need to preserve unknown tags when sending\n     * a completion item back to the server in a resolve call.\n     *\n     * @since 3.15.0\n     */\n    tagSupport?: {\n      /**\n       * The tags supported by the client.\n       */\n      valueSet: CompletionItemTag[]\n    }\n  };\n\n    completionItemKind?: {\n      /**\n       * The completion item kind values the client supports. When this\n       * property exists the client also guarantees that it will\n       * handle values outside its set gracefully and falls back\n       * to a default value when unknown.\n       *\n       * If this property is not present the client only supports\n       * the completion items kinds from `Text` to `Reference` as defined in\n       * the initial version of the protocol.\n       */\n      valueSet?: CompletionItemKind[];\n    };\n\n    /**\n     * The client supports to send additional context information for a\n     * `textDocument/completion` request.\n     */\n    contextSupport?: boolean;\n}\n\n/**\n * Describes the content type that a client supports in various\n * result literals like `Hover`, `ParameterInfo` or `CompletionItem`.\n *\n * Please note that `MarkupKinds` must not start with a `$`. This kinds\n * are reserved for internal usage.\n */\nexport enum MarkupKind {\n  /**\n   * Plain text is supported as a content format\n   */\n  PlainText = 'plaintext',\n\n  /**\n   * Markdown is supported as a content format\n   */\n  Markdown = 'markdown',\n}\n\n/**\n * https://microsoft.github.io/language-server-protocol/specifications/specification-current/#textDocument_hover\n */\nexport declare interface HoverClientCapabilities {\n    /**\n     * Whether hover supports dynamic registration.\n     */\n    dynamicRegistration?: boolean;\n\n    /**\n     * Client supports the follow content formats for the content\n     * property. The order describes the preferred format of the client.\n     */\n    contentFormat?: MarkupKind[];\n}\n\n/**\n * Completion item tags are extra annotations that tweak the rendering of\n * a completion item.\n *\n * @since 3.15.0\n */\nexport enum CompletionItemTag {\n  /**\n   * Render a completion as obsolete, usually using a strike-out.\n   */\n  Deprecated = 1,\n}\n\n/**\n * The kind of a completion entry.\n */\nexport enum CompletionItemKind {\n  Text = 1,\n  Method = 2,\n  Function = 3,\n  Constructor = 4,\n  Field = 5,\n  Variable = 6,\n  Class = 7,\n  Interface = 8,\n  Module = 9,\n  Property = 10,\n  Unit = 11,\n  Value = 12,\n  Enum = 13,\n  Keyword = 14,\n  Snippet = 15,\n  Color = 16,\n  File = 17,\n  Reference = 18,\n  Folder = 19,\n  EnumMember = 20,\n  Constant = 21,\n  Struct = 22,\n  Event = 23,\n  Operator = 24,\n  TypeParameter = 25,\n}\n\n\n/**\n * An item to transfer a text document from the client to the server.\n * https://microsoft.github.io/language-server-protocol/specifications/specification-current/#textDocumentItem\n */\nexport declare interface TextDocumentItem {\n    /**\n     * The text document's URI.\n     */\n    uri: protocol.DocumentUri;\n\n    /**\n     * The text document's language identifier.\n     */\n    languageId: LanguageIdentifier;\n\n    /**\n     * The version number of this document (it will increase after each\n     * change, including undo/redo).\n     */\n    version: number;\n\n    /**\n     * The content of the opened text document.\n     */\n    text: string;\n}\n\n/**\n * https://microsoft.github.io/language-server-protocol/specifications/specification-current/#textDocument_didOpen\n */\nexport declare interface DidOpenTextDocumentParams {\n    /**\n     * The document that was opened.\n     */\n    textDocument: TextDocumentItem;\n}\n\n/**\n * https://microsoft.github.io/language-server-protocol/specifications/specification-current/#textDocument_didOpen\n */\nexport declare interface DidOpenTextDocument extends\n    protocol.NotificationMessage<DidOpenTextDocumentParams> {\n    method: protocol.Method.TextDocumentDidOpen;\n}\n\n/**\n * https://microsoft.github.io/language-server-protocol/specifications/specification-current/#textDocument_didClose\n */\nexport declare interface DidCloseTextDocumentParams {\n    /**\n     * The document that was closed.\n     */\n    textDocument: TextDocumentIdentifier;\n}\n\n/**\n * Known language identifiers.\n * https://microsoft.github.io/language-server-protocol/specifications/specification-current/#textDocumentItem\n */\nexport enum LanguageIdentifier {\n  ABAP = 'abap',\n  WindowsBat = 'bat',\n  BibTeX = 'bibtex',\n  Clojure = 'clojure',\n  Coffeescript = 'coffeescript',\n  C = 'c',\n  CPlusPlus = 'cpp',\n  CSharp = 'csharp',\n  CSS = 'css',\n  Diff = 'diff',\n  Dart = 'dart',\n  Dockerfile = 'dockerfile',\n  Elixir = 'elixir',\n  Erlang = 'erlang',\n  FSharp = 'fsharp',\n  GitCommit = 'git-commit',\n  GitRebase = 'git-rebase',\n  Go = 'go',\n  Groovy = 'groovy',\n  Handlebars = 'handlebars',\n  HTML = 'html',\n  Ini = 'ini',\n  Java = 'java',\n  JavaScript = 'javascript',\n  JavaScriptReact = 'javascriptreact',\n  JSON = 'json',\n  LaTeX = 'latex',\n  Less = 'less',\n  Lua = 'lua',\n  Makefile = 'makefile',\n  Markdown = 'markdown',\n  ObjectiveC = 'c',\n  ObjectiveCPlusPlus = 'cpp',\n  Perl = 'perl',\n  Perl6 = 'perl6',\n  PHP = 'php',\n  Powershell = 'powershell',\n  Pug = 'jade',\n  Python = 'python',\n  R = 'r',\n  Razor = 'razor',\n  Ruby = 'ruby',\n  Rust = 'rust',\n  SCSS = 'scss',\n  Sass = 'syntax',\n  Scala = 'scala',\n  ShaderLab = 'shaderlab',\n  Shell = 'shellscript',\n  SQL = 'sql',\n  Swift = 'swift',\n  TypeScript = 'typescript',\n  TypeScriptReact = 'typescriptreact',\n  TeX = 'tex',\n  VisualBasic = 'vb',\n  XML = 'xml',\n  XSL = 'xsl',\n  YAML = 'yaml',\n}\n\n/**\n * https://microsoft.github.io/language-server-protocol/specifications/specification-current/#textDocument_publishDiagnostics\n */\nexport declare interface PublishDiagnosticsClientCapabilities {\n    /**\n     * Whether the clients accepts diagnostics with related information.\n     */\n    relatedInformation?: boolean;\n\n    /**\n     * Client supports the tag property to provide meta data about a diagnostic.\n     * Clients supporting tags have to handle unknown tags gracefully.\n     *\n     * @since 3.15.0\n     */\n    tagSupport?: {\n      /**\n       * The tags supported by the client.\n       */\n      valueSet: protocol.DiagnosticTag[];\n    };\n\n    /**\n     * Whether the client interprets the version property of the\n     * `textDocument/publishDiagnostics` notification's parameter.\n     *\n     * @since 3.15.0\n     */\n    versionSupport?: boolean;\n}\n\n/**\n * Diagnostics notification are sent from the server to the client to signal\n * results of validation runs.\n * https://microsoft.github.io/language-server-protocol/specifications/specification-current/#textDocument_publishDiagnostics\n */\nexport declare interface PublishDiagnostics extends\n    protocol.NotificationMessage<PublishDiagnosticsParams> {\n    method: protocol.Method.TextDocumentPublishDiagnostics;\n}\n\n/**\n * https://microsoft.github.io/language-server-protocol/specifications/specification-current/#textDocument_publishDiagnostics\n */\nexport declare interface PublishDiagnosticsParams {\n    /**\n     * The URI for which diagnostic information is reported.\n     */\n    uri: protocol.DocumentUri;\n\n    /**\n     * The version number of the document the diagnostics are published for.\n     * Optional.\n     * @since 3.15.0\n     */\n    version?: number;\n\n    /**\n     * An array of diagnostic information items.\n     */\n    diagnostics: protocol.Diagnostic[];\n}\n\n/**\n * Text documents are identified using a URI. On the protocol level, URIs are\n * passed as strings. The corresponding JSON structure looks like this:\n * https://microsoft.github.io/language-server-protocol/specifications/specification-current/#textDocumentIdentifier\n */\nexport declare interface TextDocumentIdentifier {\n    /**\n     * The text document's URI.\n     */\n    uri: protocol.DocumentUri;\n}\n\n/**\n * An identifier to denote a specific version of a text document. This\n * information usually flows from the client to the server.\n */\ninterface VersionedTextDocumentIdentifier extends TextDocumentIdentifier {\n    /**\n     * The version number of this document.\n     *\n     * The version number of a document will increase after each change,\n     * including undo/redo. The number doesn't need to be consecutive.\n     */\n    version: protocol.integer;\n}\n\n/**\n * https://microsoft.github.io/language-server-protocol/specifications/specification-current/#textDocumentPositionParams\n */\nexport interface TextDocumentPositionParams {\n    /**\n     * The text document.\n     */\n    textDocument: TextDocumentIdentifier;\n\n    /**\n     * The position inside the text document.\n     */\n    position: protocol.Position;\n}\n\n/**\n * The Completion request is sent from the client to the server to compute\n * completion items at a given cursor position. Completion items are presented\n * in the IntelliSense user interface. If computing full completion items is\n * expensive, servers can additionally provide a handler for the completion\n * item resolve request (`completionItem/resolve`). This request is sent when a\n * completion item is selected in the user interface. A typical use case is for\n * example: the `textDocument/completion` request doesn’t fill in the\n * documentation property for returned completion items since it is expensive\n * to compute. When the item is selected in the user interface then a\n * `completionItem/resolve` request is sent with the selected completion item\n * as a parameter. The returned completion item should have the documentation\n * property filled in. By default the request can only delay the computation of\n * the detail and documentation properties. Since 3.16.0 the client can signal\n * that it can resolve more properties lazily. This is done using the\n * completionItem#resolveSupport client capability which lists all properties\n * that can be filled in during a `completionItem/resolve` request. All other\n * properties (usually sortText, filterText, insertText and textEdit) must be\n * provided in the textDocument/completion response and must not be changed\n * during resolve.\n * https://microsoft.github.io/language-server-protocol/specifications/specification-current/#textDocument_completion\n */\nexport declare interface Completion extends\n    protocol.RequestMessage<CompletionParams> {\n    method: protocol.Method.TextDocumentCompletion;\n}\n\n/**\n * Params for the autoExecuteCheck call. This is a custom LSP command that\n * verifies that the provided code passes a number of LSP-related checks.\n */\nexport declare interface AutoExecuteCheckParams extends TextDocumentIdentifier {\n    /**\n     * The code to check whether it can be auto executed in the current\n     * document.\n     */\n    codeToCheck: string;\n\n    /**\n     * The position to insert the code at. If not set, append to the end of the\n     * notebook.\n     */\n    position?: protocol.Position;\n}\n\n/**\n * Response for the autoExecuteCheck call.\n */\nexport declare interface AutoExecuteCheckResponse {\n    /**\n     * Errors found when checking the code in the request. An empty list means\n     * that all checks passed and the code can be executed automatically.\n     */\n    errors: string[];\n\n    /**\n     * The actual code that should be executed. This will usually be the code\n     * that was passed in the request, but may include additional edits to make\n     * the code safer to run.\n     */\n    codeToExecute: string;\n}\n\n/**\n * https://microsoft.github.io/language-server-protocol/specifications/specification-current/#textDocument_completion\n */\nexport declare interface CompletionParams extends\n    TextDocumentPositionParams, protocol.WorkDoneProgressParams,\n    protocol.PartialResultParams {\n    /**\n     * The completion context. This is only available if the client specifies\n     * to send this using the client capability\n     * `completion.contextSupport === true`\n     */\n    context?: CompletionContext;\n}\n\n/**\n * How a completion was triggered\n * https://microsoft.github.io/language-server-protocol/specifications/specification-current/#textDocument_completion\n */\nexport enum CompletionTriggerKind {\n  /**\n   * Completion was triggered by typing an identifier (24x7 code\n   * complete), manual invocation (e.g Ctrl+Space) or via API.\n   */\n  Invoked = 1,\n\n  /**\n   * Completion was triggered by a trigger character specified by\n   * the `triggerCharacters` properties of the\n   * `CompletionRegistrationOptions`.\n   */\n  TriggerCharacter = 2,\n\n  /**\n   * Completion was re-triggered as the current completion list is incomplete.\n   */\n  TriggerForIncompleteCompletions = 3,\n}\n\n\n/**\n * Contains additional information about the context in which a completion\n * request is triggered.\n * https://microsoft.github.io/language-server-protocol/specifications/specification-current/#textDocument_completion\n */\nexport declare interface CompletionContext {\n    /**\n     * How the completion was triggered.\n     */\n    triggerKind: CompletionTriggerKind;\n\n    /**\n     * The trigger character (a single character) that has trigger code\n     * complete. Is undefined if\n     * `triggerKind !== CompletionTriggerKind.TriggerCharacter`\n     */\n    triggerCharacter?: string;\n}\n\n/**\n * The document change notification is sent from the client to the server to\n * signal changes to a text document. Before a client can change a text\n * document it must claim ownership of its content using the\n * textDocument/didOpen notification. In 2.0 the shape of the params has\n * changed to include proper version numbers and language ids.\n * https://microsoft.github.io/language-server-protocol/specifications/specification-current/#textDocument_didChange\n */\nexport interface DidChangeTextDocumentParams {\n    /**\n     * The document that did change. The version number points\n     * to the version after all provided content changes have\n     * been applied.\n     */\n    textDocument: VersionedTextDocumentIdentifier;\n\n    /**\n     * The actual content changes. The content changes describe single state\n     * changes to the document. So if there are two content changes c1 (at\n     * array index 0) and c2 (at array index 1) for a document in state S then\n     * c1 moves the document from S to S' and c2 from S' to S''. So c1 is\n     * computed on the state S and c2 is computed on the state S'.\n     *\n     * To mirror the content of a document using change events use the following\n     * approach:\n     * - start with the same initial content\n     * - apply the 'textDocument/didChange' notifications in the order you\n     *   receive them.\n     * - apply the `TextDocumentContentChangeEvent`s in a single notification\n     *   in the order you receive them.\n     */\n    contentChanges: TextDocumentContentChangeEvent[];\n}\n\n/**\n * An event describing a change to a text document. If range and rangeLength are\n * omitted the new text is considered to be the full content of the document.\n * https://microsoft.github.io/language-server-protocol/specifications/specification-current/#textDocument_didChange\n */\nexport type TextDocumentContentChangeEvent = {\n  /**\n   * The range of the document that changed.\n   */\n  range: protocol.Range;\n\n  /**\n   * The optional length of the range that got replaced.\n   *\n   * @deprecated use range instead.\n   */\n  rangeLength?: protocol.uinteger;\n\n  /**\n   * The new text for the provided range.\n   */\n  text: string;\n}|{\n    /**\n     * The new text of the whole document.\n     */\n    text: string;\n};\n\n/**\n * https://microsoft.github.io/language-server-protocol/specifications/specification-current/#textDocumentEdit\n */\nexport declare interface TextDocumentEdit {\n    /**\n     * The text document to change.\n     */\n    textDocument: VersionedTextDocumentIdentifier;\n\n    /**\n     * The edits to be applied.\n     */\n    edits: TextEdit[];\n}\n\n/**\n * https://microsoft.github.io/language-server-protocol/specifications/specification-current/#textEdit\n */\nexport interface TextEdit {\n    /**\n     * The range of the text document to be manipulated. To insert\n     * text into a document create a range where start === end.\n     */\n    range: protocol.Range;\n\n    /**\n     * The string to be inserted. For delete operations use an\n     * empty string.\n     */\n    newText: string;\n}\n\n/**\n * https://microsoft.github.io/language-server-protocol/specifications/specification-current/#textDocument_foldingRange\n */\nexport declare interface FoldingRangeClientCapabilities {\n    /**\n     * Whether the implementation supports dynamic registration for\n     * folding range providers.\n     * If this is set to `true`, the client supports the new\n     * `FoldingRangeRegistrationOptions` return value for the corresponding\n     * server capability as well.\n     */\n    dynamicRegistration?: boolean;\n    /**\n     * The maximum number of folding ranges that the client prefers to\n     * receive per document.\n     * The value serves as a hint, servers are free to follow the limit.\n     */\n    rangeLimit?: number;\n    /**\n     * If set, the client signals that it only supports folding complete lines.\n     * If set, the client will ignore specified `startCharacter` and\n     * `endCharacter` properties in a FoldingRange.\n     */\n    lineFoldingOnly?: boolean;\n}\n\n/**\n * The document range formatting request is sent from the client to the server\n * to format a given range in a document.\n */\nexport declare interface DocumentRangeFormattingClientCapabilities {\n    /**\n     * Whether formatting supports dynamic registration.\n     */\n    dynamicRegistration?: boolean;\n}\n\n/**\n * https://microsoft.github.io/language-server-protocol/specifications/specification-current/#textDocument_selectionRange\n */\nexport declare interface SelectionRangeClientCapabilities {\n    /**\n     * Whether implementation supports dynamic registration for selection\n     * range providers.\n     * If set to `true`, the client supports the new\n     * `SelectionRangeRegistrationOptions` return value for the corresponding\n     * server capability as well.\n     */\n    dynamicRegistration?: boolean;\n}\n\n/**\n * https://microsoft.github.io/language-server-protocol/specifications/specification-current/#textDocument_signatureHelp\n */\nexport declare interface SignatureHelpClientCapabilities {\n    /**\n     * Whether signature help supports dynamic registration.\n     */\n    dynamicRegistration?: boolean;\n\n    /**\n     * The client supports the following `SignatureInformation`\n     * specific properties.\n     */\n    signatureInformation?: {\n      /**\n       * Client supports the follow content formats for the documentation\n       * property. The order describes the preferred format of the client.\n       */\n      documentationFormat?: MarkupKind[];\n\n      /**\n       * Client capabilities specific to parameter information.\n       */\n      parameterInformation?: {\n        /**\n         * The client supports processing label offsets instead of a\n         * simple label string.\n         *\n         * @since 3.14.0\n         */\n        labelOffsetSupport?: boolean;\n      };\n\n      /**\n       * The client supports the `activeParameter` property on\n       * `SignatureInformation` literal.\n       *\n       * @since 3.16.0 - proposed state\n       */\n      activeParameterSupport?: boolean;\n    };\n\n    /**\n     * The client supports to send additional context information for a\n     * `textDocument/signatureHelp` request. A client that opts into\n     * contextSupport will also support the `retriggerCharacters` on\n     * `SignatureHelpOptions`.\n     *\n     * @since 3.15.0\n     */\n    contextSupport?: boolean;\n}\n\n/**\n * https://microsoft.github.io/language-server-protocol/specifications/specification-current/#textDocument_implementation\n */\nexport declare interface ImplementationClientCapabilities {\n    /**\n     * Whether implementation supports dynamic registration.\n     * If this is set to `true`, the client supports the new\n     * `ImplementationRegistrationOptions` return value for the\n     * corresponding server capability as well.\n     */\n    dynamicRegistration?: boolean;\n\n    /**\n     * The client supports additional metadata in the form of definition links.\n     *\n     * @since 3.14.0\n     */\n    linkSupport?: boolean;\n}\n\n/**\n * The rename request is sent from the client to the server to ask the server to\n * compute a workspace change so that the client can perform a workspace-wide\n * rename of a symbol.\n */\nexport declare interface RenameClientCapabilities {\n    /**\n     * Whether rename supports dynamic registration.\n     */\n    dynamicRegistration?: boolean;\n\n    /**\n     * Client supports testing for validity of rename operations\n     * before execution.\n     *\n     * @since version 3.12.0\n     */\n    prepareSupport?: boolean;\n}\n\n/**\n * https://microsoft.github.io/language-server-protocol/specifications/specification-current/#textDocument_typeDefinition\n */\nexport declare interface TypeDefinitionClientCapabilities {\n    /**\n     * Whether implementation supports dynamic registration.\n     * If this is set to `true`, the client supports the new `\n     * TypeDefinitionRegistrationOptions` return value for the\n     * corresponding server capability as well.\n     */\n    dynamicRegistration?: boolean;\n\n    /**\n     * The client supports additional metadata in the form of definition links.\n     *\n     * @since 3.14.0\n     */\n    linkSupport?: boolean;\n}\n\n/**\n * https://microsoft.github.io/language-server-protocol/specifications/specification-current/#textDocument_didClose\n */\nexport declare interface TextDocumentSyncClientCapabilities {\n    /**\n     * Whether text document synchronization supports dynamic registration.\n     */\n    dynamicRegistration?: boolean;\n\n    /**\n     * The client supports sending will save notifications.\n     */\n    willSave?: boolean;\n\n    /**\n     * The client supports sending a will save request and\n     * waits for a response providing text edits which will\n     * be applied to the document before it is saved.\n     */\n    willSaveWaitUntil?: boolean;\n\n    /**\n     * The client supports did save notifications.\n     */\n    didSave?: boolean;\n}\n\n/**\n * Defines how the host (editor) should sync document changes\n * to the language server.\n */\nexport enum TextDocumentSyncKind {\n  /**\n   * Documents should not be synced at all.\n   */\n  None = 0,\n\n  /**\n   * Documents are synced by always sending the full content\n   * of the document.\n   */\n  Full = 1,\n\n  /**\n   * Documents are synced by sending the full content on open.\n   * After that only incremental updates to the document are\n   * send.\n   */\n  Incremental = 2,\n}\n\n/**\n * https://microsoft.github.io/language-server-protocol/specifications/specification-current/#textDocument_didClose\n */\nexport declare interface TextDocumentSyncOptions {\n    /**\n     * Open and close notifications are sent to the server.\n     * If omitted, open close notification should not be sent.\n     */\n    openClose?: boolean;\n    /**\n     * Change notifications are sent to the server.\n     * See TextDocumentSyncKind.None, TextDocumentSyncKind.Full,\n     * and TextDocumentSyncKind.Incremental.\n     * If omitted, it defaults to TextDocumentSyncKind.None.\n     */\n    change?: number;\n    /**\n     * If present will save notifications are sent to the server.\n     * If omitted, the notification should not be sent.\n     */\n    willSave?: boolean;\n    /**\n     * If present will save wait until requests are sent to the server.\n     * If omitted, the request should not be sent.\n     */\n    willSaveWaitUntil?: boolean;\n    /**\n     * If present save notifications are sent to the server.\n     * If omitted, the notification should not be sent.\n     */\n    save?: boolean|SaveOptions;\n}\n\n/**\n * https://microsoft.github.io/language-server-protocol/specifications/specification-current/#textDocument_didSave\n */\nexport declare interface SaveOptions {\n    /**\n     * The client is supposed to include the content on save.\n     */\n    includeText?: boolean;\n}\n\n/**\n * https://microsoft.github.io/language-server-protocol/specifications/specification-current/#textDocument_definition\n */\nexport declare interface DefinitionClientCapabilities {\n    /**\n     * Whether definition supports dynamic registration.\n     */\n    dynamicRegistration?: boolean;\n\n    /**\n     * The client supports additional metadata in the form of definition links.\n     *\n     * @since 3.14.0\n     */\n    linkSupport?: boolean;\n}\n\n/**\n * https://microsoft.github.io/language-server-protocol/specifications/specification-current/#textDocument_declaration\n */\nexport declare interface DeclarationClientCapabilities {\n    /**\n     * Whether declaration supports dynamic registration.\n     * If this is set to `true`, the client supports the new\n     * `DeclarationRegistrationOptions` return value for the\n     * corresponding server capability as well.\n     */\n    dynamicRegistration?: boolean;\n\n    /**\n     * The client supports additional metadata in the form of declaration links.\n     */\n    linkSupport?: boolean;\n}\n\n/**\n * https://microsoft.github.io/language-server-protocol/specifications/specification-current/#textDocument_documentHighlight\n */\nexport declare interface DocumentHighlightClientCapabilities {\n    /**\n     * Whether document highlight supports dynamic registration.\n     */\n    dynamicRegistration?: boolean;\n}\n\n/**\n * https://microsoft.github.io/language-server-protocol/specifications/specification-current/#textDocument_references\n */\nexport declare interface ReferenceClientCapabilities {\n    /**\n     * Whether references supports dynamic registration.\n     */\n    dynamicRegistration?: boolean;\n}\n\n/**\n * https://microsoft.github.io/language-server-protocol/specifications/specification-current/#textDocument_documentSymbol\n */\nexport declare interface DocumentSymbolClientCapabilities {\n    /**\n     * Whether document symbol supports dynamic registration.\n     */\n    dynamicRegistration?: boolean;\n\n    /**\n     * Specific capabilities for the `SymbolKind` in the\n     * `textDocument/documentSymbol` request.\n     */\n    symbolKind?: {\n      /**\n       * The symbol kind values the client supports. When this\n       * property exists the client also guarantees that it will\n       * handle values outside its set gracefully and falls back\n       * to a default value when unknown.\n       *\n       * If this property is not present the client only supports\n       * the symbol kinds from `File` to `Array` as defined in\n       * the initial version of the protocol.\n       */\n      valueSet?: protocol.SymbolKind[];\n    };\n\n    /**\n     * The client supports hierarchical document symbols.\n     */\n    hierarchicalDocumentSymbolSupport?: boolean;\n\n    /**\n     * The client supports tags on `SymbolInformation`. Tags are supported on\n     * `DocumentSymbol` if `hierarchicalDocumentSymbolSupport` is set to true.\n     * Clients supporting tags have to handle unknown tags gracefully.\n     *\n     * @since 3.16.0\n     */\n    tagSupport?: {\n      /**\n       * The tags supported by the client.\n       */\n      valueSet: protocol.SymbolTag[]\n    };\n\n    /**\n     * The client supports an additional label presented in the UI when\n     * registering a document symbol provider.\n     *\n     * @since 3.16.0\n     */\n    labelSupport?: boolean;\n}\n\n/**\n * The document on type formatting request is sent from the client to the server\n * to format parts of the document during typing.\n */\nexport declare interface DocumentOnTypeFormattingClientCapabilities {\n    /**\n     * Whether on type formatting supports dynamic registration.\n     */\n    dynamicRegistration?: boolean;\n}\n\n/**\n * The document formatting request is sent from the client to the server to\n * format a whole document.\n */\nexport declare interface DocumentFormattingClientCapabilities {\n    /**\n     * Whether formatting supports dynamic registration.\n     */\n    dynamicRegistration?: boolean;\n}\n\n/**\n * The document color request is sent from the client to the server to list all\n * color references found in a given text document. Along with the range, a\n * color value in RGB is returned. Clients can use the result to decorate color\n * references in an editor. For example: Color boxes showing the actual color\n * next to the reference Show a color picker when a color reference is edited\n */\nexport declare interface DocumentColorClientCapabilities {\n    /**\n     * Whether document color supports dynamic registration.\n     */\n    dynamicRegistration?: boolean;\n}\n\n/**\n * The document links request is sent from the client to the server to request\n * the location of links in a document.\n */\nexport declare interface DocumentLinkClientCapabilities {\n    /**\n     * Whether document link supports dynamic registration.\n     */\n    dynamicRegistration?: boolean;\n\n    /**\n     * Whether the client supports the `tooltip` property on `DocumentLink`.\n     *\n     * @since 3.15.0\n     */\n    tooltipSupport?: boolean;\n}\n\n/**\n * The CodeLens request is sent from the client to the server to compute\n * CodeLens for a given text document.\n */\nexport declare interface CodeLensClientCapabilities {\n    /**\n     * Whether CodeLens supports dynamic registration.\n     */\n    dynamicRegistration?: boolean;\n}\n\n/**\n * https://microsoft.github.io/language-server-protocol/specifications/specification-current/#textDocument_codeAction\n */\nexport declare interface CodeActionClientCapabilities {\n    /**\n     * Whether code action supports dynamic registration.\n     */\n    dynamicRegistration?: boolean;\n\n    /**\n     * The client supports code action literals as a valid\n     * response of the `textDocument/codeAction` request.\n     *\n     * @since 3.8.0\n     */\n    codeActionLiteralSupport?: {\n      /**\n       * The code action kind is supported with the following value\n       * set.\n       */\n      codeActionKind: {\n\n        /**\n         * The code action kind values the client supports. When this\n         * property exists the client also guarantees that it will\n         * handle values outside its set gracefully and falls back\n         * to a default value when unknown.\n         */\n        valueSet: CodeActionKind[];\n      };\n    };\n\n    /**\n     * Whether code action supports the `isPreferred` property.\n     * @since 3.15.0\n     */\n    isPreferredSupport?: boolean;\n}\n\n/**\n * The kind of a code action.\n *\n * Kinds are a hierarchical list of identifiers separated by `.`,\n * e.g. `\"refactor.extract.function\"`.\n *\n * The set of kinds is open and the client needs to announce the kinds it\n * supports to the server during initialization.\n */\nexport enum CodeActionKind {\n\n  /**\n   * Empty kind.\n   */\n  Empty = '',\n\n  /**\n   * Base kind for quickfix actions: 'quickfix'.\n   */\n  QuickFix = 'quickfix',\n\n  /**\n   * Base kind for refactoring actions: 'refactor'.\n   */\n  Refactor = 'refactor',\n\n  /**\n   * Base kind for refactoring extraction actions: 'refactor.extract'.\n   *\n   * Example extract actions:\n   *\n   * - Extract method\n   * - Extract function\n   * - Extract variable\n   * - Extract interface from class\n   * - ...\n   */\n  RefactorExtract = 'refactor.extract',\n\n  /**\n   * Base kind for refactoring inline actions: 'refactor.inline'.\n   *\n   * Example inline actions:\n   *\n   * - Inline function\n   * - Inline variable\n   * - Inline constant\n   * - ...\n   */\n  RefactorInline = 'refactor.inline',\n\n  /**\n   * Base kind for refactoring rewrite actions: 'refactor.rewrite'.\n   *\n   * Example rewrite actions:\n   *\n   * - Convert JavaScript function to class\n   * - Add or remove parameter\n   * - Encapsulate field\n   * - Make method static\n   * - Move method to base class\n   * - ...\n   */\n  RefactorRewrite = 'refactor.rewrite',\n\n  /**\n   * Base kind for source actions: `source`.\n   *\n   * Source code actions apply to the entire file.\n   */\n  Source = 'source',\n\n  /**\n   * Base kind for an organize imports source action `source.organizeImports`.\n   */\n  SourceOrganizeImports = 'source.organizeImports',\n}\n\n/**\n * Contains additional diagnostic information about the context in which\n * a code action is run.\n */\nexport declare interface CodeActionContext {\n    /**\n     * An array of diagnostics known on the client side overlapping the range\n     * provided to the `textDocument/codeAction` request.\n     * They are provided so that the server knows which errors are currently\n     * presented to the user for the given range. There is no guarantee that\n     * these accurately reflect the error state of the resource.\n     * The primary parameter to compute code actions is the provided range.\n     */\n    diagnostics: protocol.Diagnostic[];\n\n    /**\n     * Requested kind of actions to return.\n     *\n     * Actions not of this kind are filtered out by the client before\n     * being shown, so servers can omit computing them.\n     */\n    only?: CodeActionKind[];\n}\n\n/**\n * https://microsoft.github.io/language-server-protocol/specifications/specification-current/#textDocument_publishDiagnostics\n */\nexport declare interface PublishDiagnosticsClientCapabilities {\n    /**\n     * Whether the clients accepts diagnostics with related information.\n     */\n    relatedInformation?: boolean;\n\n    /**\n     * Client supports the tag property to provide meta data about a diagnostic.\n     * Clients supporting tags have to handle unknown tags gracefully.\n     *\n     * @since 3.15.0\n     */\n    tagSupport?: {\n      /**\n       * The tags supported by the client.\n       */\n      valueSet: protocol.DiagnosticTag[];\n    };\n\n    /**\n     * Whether the client interprets the version property of the\n     * `textDocument/publishDiagnostics` notification's parameter.\n     *\n     * @since 3.15.0\n     */\n    versionSupport?: boolean;\n}\n\n/**\n * Represents a collection of [completion items](#CompletionItem) to be\n * presented in the editor.\n */\nexport interface CompletionList {\n    /**\n     * This list it not complete. Further typing should result in recomputing\n     * this list.\n     */\n    isIncomplete: boolean;\n\n    /**\n     * The completion items.\n     */\n    items: CompletionItem[];\n}\n\n/**\n * Defines whether the insert text in a completion item should be interpreted as\n * plain text or a snippet.\n */\nexport enum InsertTextFormat {\n  /**\n   * The primary text to be inserted is treated as a plain string.\n   */\n  PlainText = 1,\n\n  /**\n   * The primary text to be inserted is treated as a snippet.\n   *\n   * A snippet can define tab stops and placeholders with `$1`, `$2`\n   * and `${3:foo}`. `$0` defines the final tab stop, it defaults to\n   * the end of the snippet. Placeholders with equal identifiers are linked,\n   * that is typing in one will update others too.\n   */\n  Snippet = 2,\n}\n\n/**\n * A special text edit to provide an insert and a replace operation.\n *\n * @since 3.16.0\n */\nexport interface InsertReplaceEdit {\n    /**\n     * The string to be inserted.\n     */\n    newText: string;\n\n    /**\n     * The range if the insert is requested\n     */\n    insert: protocol.Range;\n\n    /**\n     * The range if the replace is requested.\n     */\n    replace: protocol.Range;\n}\n\n/**\n * How whitespace and indentation is handled during completion\n * item insertion.\n *\n * @since 3.16.0\n */\nexport enum InsertTextMode {\n  /**\n   * The insertion or replace strings is taken as it is. If the\n   * value is multi line the lines below the cursor will be\n   * inserted using the indentation defined in the string value.\n   * The client will not apply any kind of adjustments to the\n   * string.\n   */\n  asIs = 1,\n\n  /**\n   * The editor adjusts leading whitespace of new lines so that\n   * they match the indentation up to the cursor of the line for\n   * which the item is accepted.\n   *\n   * Consider a line like this: <2tabs><cursor><3tabs>foo. Accepting a\n   * multi line completion item is indented using 2 tabs and all\n   * following lines inserted will be indented using 2 tabs as well.\n   */\n  adjustIndentation = 2,\n}\n\n/**\n * https://microsoft.github.io/language-server-protocol/specifications/specification-current/#textDocument_completion\n */\nexport interface CompletionItem {\n    /**\n     * The label of this completion item. By default\n     * also the text that is inserted when selecting\n     * this completion.\n     */\n    label: string;\n\n    /**\n     * The kind of this completion item. Based of the kind\n     * an icon is chosen by the editor. The standardized set\n     * of available values is defined in `CompletionItemKind`.\n     */\n    kind?: CompletionItemKind;\n\n    /**\n     * Tags for this completion item.\n     *\n     * @since 3.15.0\n     */\n    tags?: CompletionItemTag[];\n\n    /**\n     * A human-readable string with additional information\n     * about this item, like type or symbol information.\n     */\n    detail?: string;\n\n    /**\n     * A human-readable string that represents a doc-comment.\n     */\n    documentation?: string|MarkupContent;\n\n    /**\n     * Indicates if this item is deprecated.\n     *\n     * @deprecated Use `tags` instead if supported.\n     */\n    deprecated?: boolean;\n\n    /**\n     * Select this item when showing.\n     *\n     * *Note* that only one completion item can be selected and that the\n     * tool / client decides which item that is. The rule is that the *first*\n     * item of those that match best is selected.\n     */\n    preselect?: boolean;\n\n    /**\n     * A string that should be used when comparing this item\n     * with other items. When `falsy` the label is used.\n     */\n    sortText?: string;\n\n    /**\n     * A string that should be used when filtering a set of\n     * completion items. When `falsy` the label is used.\n     */\n    filterText?: string;\n\n    /**\n     * A string that should be inserted into a document when selecting\n     * this completion. When `falsy` the label is used.\n     *\n     * The `insertText` is subject to interpretation by the client side.\n     * Some tools might not take the string literally. For example\n     * VS Code when code complete is requested in this example\n     * `con<cursor position>` and a completion item with an `insertText` of\n     * `console` is provided it will only insert `sole`. Therefore it is\n     * recommended to use `textEdit` instead since it avoids additional client\n     * side interpretation.\n     */\n    insertText?: string;\n\n    /**\n     * The format of the insert text. The format applies to both the\n     * `insertText` property and the `newText` property of a provided\n     * `textEdit`. If omitted defaults to `InsertTextFormat.PlainText`.\n     */\n    insertTextFormat?: InsertTextFormat;\n\n    /**\n     * How whitespace and indentation is handled during completion\n     * item insertion. If not provided the client's default value depends on\n     * the `textDocument.completion.insertTextMode` client capability.\n     *\n     * @since 3.16.0\n     */\n    insertTextMode?: InsertTextMode;\n\n    /**\n     * An edit which is applied to a document when selecting this completion.\n     * When an edit is provided the value of `insertText` is ignored.\n     *\n     * *Note:* The range of the edit must be a single line range and it must\n     * contain the position at which completion has been requested.\n     *\n     * Most editors support two different operations when accepting a completion\n     * item. One is to insert a completion text and the other is to replace an\n     * existing text with a completion text. Since this can usually not be\n     * predetermined by a server it can report both ranges. Clients need to\n     * signal support for `InsertReplaceEdits` via the\n     * `textDocument.completion.insertReplaceSupport` client capability\n     * property.\n     *\n     * *Note 1:* The text edit's range as well as both ranges from an insert\n     * replace edit must be a [single line] and they must contain the position\n     * at which completion has been requested.\n     * *Note 2:* If an `InsertReplaceEdit` is returned the edit's insert range\n     * must be a prefix of the edit's replace range, that means it must be\n     * contained and starting at the same position.\n     *\n     * @since 3.16.0 additional type `InsertReplaceEdit`\n     */\n    textEdit?: TextEdit|InsertReplaceEdit;\n\n    /**\n     * An optional array of additional text edits that are applied when\n     * selecting this completion. Edits must not overlap (including the same\n     * insert position) with the main edit nor with themselves.\n     *\n     * Additional text edits should be used to change text unrelated to the\n     * current cursor position (for example adding an import statement at the\n     * top of the file if the completion item will insert an unqualified type).\n     */\n    additionalTextEdits?: TextEdit[];\n\n    /**\n     * An optional set of characters that when pressed while this completion is\n     * active will accept it first and then type that character. *Note* that all\n     * commit characters should have `length=1` and that superfluous characters\n     * will be ignored.\n     */\n    commitCharacters?: string[];\n\n    /**\n     * An optional command that is executed *after* inserting this completion.\n     * *Note* that additional modifications to the current document should be\n     * described with the additionalTextEdits-property.\n     */\n    command?: protocol.Command;\n\n    /**\n     * A data entry field that is preserved on a completion item between\n     * a completion and a completion resolve request.\n     */\n    data?: unknown;\n}\n\n\n// tslint:disable:jsdoc-format\n/**\n * A `MarkupContent` literal represents a string value which content is\n * interpreted base on its kind flag. Currently the protocol supports\n * `plaintext` and `markdown` as markup kinds.\n *\n * If the kind is `markdown` then the value can contain fenced code blocks like\n * in GitHub issues.\n *\n * Here is an example how such a string can be constructed using\n * JavaScript / TypeScript:\n * ```typescript\n * let markdown: MarkdownContent = {\n *  kind: MarkupKind.Markdown,\n *  value: [\n *    '# Header',\n *    'Some text',\n *    '```typescript',\n *    'someCode();',\n *    '```'\n *  ].join('\\n')\n * };\n * ```\n *\n * *Please Note* that clients might sanitize the return markdown. A client could\n * decide to remove HTML from the markdown to avoid script execution.\n */\n// tslint:enable:jsdoc-format\nexport interface MarkupContent {\n    /**\n     * The type of the Markup\n     */\n    kind: MarkupKind;\n\n    /**\n     * The content itself\n     */\n    value: string;\n}\n\n/**\n * https://microsoft.github.io/language-server-protocol/specifications/specification-current/#textDocument_signatureHelp\n */\nexport interface SignatureHelpParams extends TextDocumentPositionParams,\n                                             protocol.WorkDoneProgressParams {\n    /**\n     * The signature help context. This is only available if the client\n     * specifies to send this using the client capability\n     * `textDocument.signatureHelp.contextSupport === true`\n     *\n     * @since 3.15.0\n     */\n    context?: SignatureHelpContext;\n}\n\n/**\n * How a signature help was triggered.\n *\n * @since 3.15.0\n */\nexport enum SignatureHelpTriggerKind {\n  /**\n   * Signature help was invoked manually by the user or by a command.\n   */\n  Invoked = 1,\n  /**\n   * Signature help was triggered by a trigger character.\n   */\n  TriggerCharacter = 2,\n  /**\n   * Signature help was triggered by the cursor moving or by the document\n   * content changing.\n   */\n  ContentChange = 3,\n}\n\n/**\n * Additional information about the context in which a signature help request\n * was triggered.\n *\n * @since 3.15.0\n */\nexport interface SignatureHelpContext {\n    /**\n     * Action that caused signature help to be triggered.\n     */\n    triggerKind: SignatureHelpTriggerKind;\n\n    /**\n     * Character that caused signature help to be triggered.\n     *\n     * This is undefined when triggerKind !==\n     * SignatureHelpTriggerKind.TriggerCharacter\n     */\n    triggerCharacter?: string;\n\n    /**\n     * `true` if signature help was already showing when it was triggered.\n     *\n     * Retriggers occur when the signature help is already active and can be\n     * caused by actions such as typing a trigger character, a cursor move, or\n     * document content changes.\n     */\n    isRetrigger: boolean;\n\n    /**\n     * The currently active `SignatureHelp`.\n     *\n     * The `activeSignatureHelp` has its `SignatureHelp.activeSignature` field\n     * updated based on the user navigating through available signatures.\n     */\n    activeSignatureHelp?: SignatureHelp;\n}\n\n/**\n * Signature help represents the signature of something\n * callable. There can be multiple signature but only one\n * active and only one active parameter.\n */\nexport interface SignatureHelp {\n    /**\n     * One or more signatures. If no signatures are available the signature help\n     * request should return `null`.\n     */\n    signatures: SignatureInformation[];\n\n    /**\n     * The active signature. If omitted or the value lies outside the\n     * range of `signatures` the value defaults to zero or is ignored if\n     * the `SignatureHelp` has no signatures.\n     *\n     * Whenever possible implementors should make an active decision about\n     * the active signature and shouldn't rely on a default value.\n     *\n     * In future version of the protocol this property might become\n     * mandatory to better express this.\n     */\n    activeSignature?: protocol.uinteger;\n\n    /**\n     * The active parameter of the active signature. If omitted or the value\n     * lies outside the range of `signatures[activeSignature].parameters`\n     * defaults to 0 if the active signature has parameters. If\n     * the active signature has no parameters it is ignored.\n     * In future version of the protocol this property might become\n     * mandatory to better express the active parameter if the\n     * active signature does have any.\n     */\n    activeParameter?: protocol.uinteger;\n}\n\n/**\n * Represents the signature of something callable. A signature\n * can have a label, like a function-name, a doc-comment, and\n * a set of parameters.\n */\nexport interface SignatureInformation {\n    /**\n     * The label of this signature. Will be shown in\n     * the UI.\n     */\n    label: string;\n\n    /**\n     * The human-readable doc-comment of this signature. Will be shown\n     * in the UI but can be omitted.\n     */\n    documentation?: string|MarkupContent;\n\n    /**\n     * The parameters of this signature.\n     */\n    parameters?: ParameterInformation[];\n\n    /**\n     * The index of the active parameter.\n     *\n     * If provided, this is used in place of `SignatureHelp.activeParameter`.\n     *\n     * @since 3.16.0\n     */\n    activeParameter?: protocol.uinteger;\n}\n\n/**\n * Represents a parameter of a callable-signature. A parameter can\n * have a label and a doc-comment.\n */\nexport interface ParameterInformation {\n    /**\n     * The label of this parameter information.\n     *\n     * Either a string or an inclusive start and exclusive end offsets within\n     * its containing signature label. (see SignatureInformation.label). The\n     * offsets are based on a UTF-16 string representation as `Position` and\n     * `Range` does.\n     *\n     * *Note*: a label of type string should be a substring of its containing\n     * signature label. Its intended use case is to highlight the parameter\n     * label part in the `SignatureInformation.label`.\n     */\n    label: string|[protocol.uinteger, protocol.uinteger];\n\n    /**\n     * The human-readable doc-comment of this parameter. Will be shown\n     * in the UI but can be omitted.\n     */\n    documentation?: string|MarkupContent;\n}\n\n/**\n * https://microsoft.github.io/language-server-protocol/specifications/specification-current/#textDocument_hover\n */\nexport interface HoverParams extends TextDocumentPositionParams,\n                                     protocol.WorkDoneProgressParams {}\n\n/**\n * The result of a hover request.\n */\nexport interface Hover {\n    /**\n     * The hover's content\n     */\n    contents: MarkupContent;\n\n    /**\n     * An optional range is a range inside a text document\n     * that is used to visualize a hover, e.g. by changing the background color.\n     */\n    range?: protocol.Range;\n}\n\n/**\n * https://microsoft.github.io/language-server-protocol/specifications/specification-3-17/#definitionParams\n */\nexport interface DefinitionParams extends TextDocumentPositionParams,\n                                          protocol.WorkDoneProgressParams,\n                                          protocol.PartialResultParams {}\n\n/**\n * Params for the custom 'echoDocument' comment which returns the current state\n * of the server's view of the LSP document.\n */\nexport interface EchoDocumentParams {}\n\n/**\n * Params for the CodeActionRequest\n */\nexport interface CodeActionParams extends protocol.WorkDoneProgressParams,\n                                          protocol.PartialResultParams {\n    /**\n     * The document in which the command was invoked.\n     */\n    textDocument: TextDocumentIdentifier;\n\n    /**\n     * The range for which the command was invoked.\n     */\n    range: protocol.Range;\n\n    /**\n     * Context carrying additional information.\n     */\n    context: CodeActionContext;\n}\n\n/**\n * Params for the RenameRequest\n */\nexport interface RenameParams extends TextDocumentPositionParams,\n                                      protocol.WorkDoneProgressParams {\n  /**\n   * The new name of the symbol. If the given name is not valid the\n   * request must return a [ResponseError](#ResponseError) with an\n   * appropriate message set.\n   */\n  newName: string;\n}\n\n/**\n * A code action represents a change that can be performed in code, e.g. to fix\n * a problem or to refactor code.\n *\n * A CodeAction must set either `edit` and/or a `command`. If both are supplied,\n * the `edit` is applied first, then the `command` is executed.\n */\nexport interface CodeAction {\n    /**\n     * A short, human-readable, title for this code action.\n     */\n    title: string;\n\n    /**\n     * The kind of the code action.\n     *\n     * Used to filter code actions.\n     */\n    kind?: CodeActionKind;\n\n    /**\n     * The diagnostics that this code action resolves.\n     */\n    diagnostics?: protocol.Diagnostic[];\n\n    /**\n     * Marks this as a preferred action. Preferred actions are used by the\n     * `auto fix` command and can be targeted by keybindings.\n     *\n     * A quick fix should be marked preferred if it properly addresses the\n     * underlying error. A refactoring should be marked preferred if it is the\n     * most reasonable choice of actions to take.\n     *\n     * @since 3.15.0\n     */\n    isPreferred?: boolean;\n\n    /**\n     * Marks that the code action cannot currently be applied.\n     *\n     * Clients should follow the following guidelines regarding disabled code\n     * actions:\n     *\n     * - Disabled code actions are not shown in automatic lightbulbs code\n     *   action menus.\n     *\n     * - Disabled actions are shown as faded out in the code action menu when\n     *   the user request a more specific type of code action, such as\n     *   refactorings.\n     *\n     * - If the user has a keybinding that auto applies a code action and only\n     *   a disabled code actions are returned, the client should show the user\n     *   an error message with `reason` in the editor.\n     *\n     * @since 3.16.0\n     */\n    disabled?: {\n\n      /**\n       * Human readable description of why the code action is currently\n       * disabled.\n       *\n       * This is displayed in the code actions UI.\n       */\n      reason: string;\n    };\n\n    /**\n     * The workspace edit this code action performs.\n     */\n    edit?: workspace.WorkspaceEdit;\n\n    /**\n     * A command this code action executes. If a code action\n     * provides an edit and a command, first the edit is\n     * executed and then the command.\n     */\n    command?: protocol.Command;\n\n    /**\n     * A data entry field that is preserved on a code action between\n     * a `textDocument/codeAction` and a `codeAction/resolve` request.\n     *\n     * @since 3.16.0\n     */\n    data?: unknown;\n}\n// tslint:enable:enforce-name-casing\n"]} |