# codegen: do not edit
defmodule GenLSP.Structures.Command do
  @moduledoc """
  Represents a reference to a command. Provides a title which
  will be used to represent a command in the UI and, optionally,
  an array of arguments which will be passed to the command handler
  function when invoked.

  import Schematic, warn: false

  use TypedStruct

  @doc """
  ## Fields

  * title: Title of the command, like `save`.
  * command: The identifier of the actual command handler.
  * arguments: Arguments that the command handler should be
    invoked with.
  @derive Jason.Encoder
  typedstruct do
    field :title, String.t(), enforce: true
    field :command, String.t(), enforce: true
    field :arguments, list(GenLSP.TypeAlias.LSPAny.t())

  @doc false
  @spec schematic() :: Schematic.t()
  def schematic() do
    schema(__MODULE__, %{
      {"title", :title} => str(),
      {"command", :command} => str(),
      optional({"arguments", :arguments}) => list(GenLSP.TypeAlias.LSPAny.schematic())