lib/gen_lsp/protocol/requests/text_document_document_highlight.ex

# codegen: do not edit
defmodule GenLSP.Requests.TextDocumentDocumentHighlight do
  @moduledoc """
  Request to resolve a {@link DocumentHighlight} for a given
  text document position. The request's parameter is of type [TextDocumentPosition]
  (#TextDocumentPosition) the request response is of type [DocumentHighlight[]]
  (#DocumentHighlight) or a Thenable that resolves to such.

  Message Direction: clientToServer
  """

  import Schematic, warn: false

  use TypedStruct

  @derive Jason.Encoder
  typedstruct do
    field :method, String.t(), default: "textDocument/documentHighlight"
    field :jsonrpc, String.t(), default: "2.0"
    field :id, integer(), enforce: true
    field :params, GenLSP.Structures.DocumentHighlightParams.t()
  end

  @type result :: list(GenLSP.Structures.DocumentHighlight.t()) | nil

  @doc false
  @spec schematic() :: Schematic.t()
  def schematic() do
    schema(__MODULE__, %{
      method: "textDocument/documentHighlight",
      jsonrpc: "2.0",
      id: int(),
      params: GenLSP.Structures.DocumentHighlightParams.schematic()
    })
  end

  @doc false
  @spec result() :: Schematic.t()
  def result() do
    oneof([
      oneof([list(GenLSP.Structures.DocumentHighlight.schematic()), nil]),
      GenLSP.ErrorResponse.schematic()
    ])
  end
end