# codegen: do not edit
defmodule GenLSP.Structures.ClientCapabilities do
@moduledoc """
Defines the capabilities provided by the client.
"""
import Schematic, warn: false
use TypedStruct
@doc """
## Fields
* workspace: Workspace specific client capabilities.
* text_document: Text document specific client capabilities.
* notebook_document: Capabilities specific to the notebook document support.
@since 3.17.0
* window: Window specific client capabilities.
* general: General client capabilities.
@since 3.16.0
* experimental: Experimental client capabilities.
"""
@derive Jason.Encoder
typedstruct do
field :workspace, GenLSP.Structures.WorkspaceClientCapabilities.t()
field :text_document, GenLSP.Structures.TextDocumentClientCapabilities.t()
field :notebook_document, GenLSP.Structures.NotebookDocumentClientCapabilities.t()
field :window, GenLSP.Structures.WindowClientCapabilities.t()
field :general, GenLSP.Structures.GeneralClientCapabilities.t()
field :experimental, GenLSP.TypeAlias.LSPAny.t()
end
@doc false
@spec schematic() :: Schematic.t()
def schematic() do
schema(__MODULE__, %{
optional({"workspace", :workspace}) =>
GenLSP.Structures.WorkspaceClientCapabilities.schematic(),
optional({"textDocument", :text_document}) =>
GenLSP.Structures.TextDocumentClientCapabilities.schematic(),
optional({"notebookDocument", :notebook_document}) =>
GenLSP.Structures.NotebookDocumentClientCapabilities.schematic(),
optional({"window", :window}) => GenLSP.Structures.WindowClientCapabilities.schematic(),
optional({"general", :general}) => GenLSP.Structures.GeneralClientCapabilities.schematic(),
optional({"experimental", :experimental}) => GenLSP.TypeAlias.LSPAny.schematic()
})
end
end