lib/gen_lsp/protocol/enumerations/insert_text_mode.ex

# codegen: do not edit
defmodule GenLSP.Enumerations.InsertTextMode do
  @moduledoc """
  How whitespace and indentation is handled during completion
  item insertion.

  @since 3.16.0
  """

  @type t :: 1 | 2

  import Schematic, warn: false

  @doc """
  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.
  """
  @spec as_is() :: 1
  def as_is, do: 1

  @doc """
  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.
  """
  @spec adjust_indentation() :: 2
  def adjust_indentation, do: 2

  @doc false
  @spec schematic() :: Schematic.t()
  def schematic() do
    oneof([
      1,
      2
    ])
  end
end