File: //proc/self/root/usr/lib/ruby/gems/3.0.0/gems/rbs-1.0.4/core/exception.rbs
# Descendants of class [Exception](Exception) are used
# to communicate between
# [Kernel\#raise](https://ruby-doc.org/core-2.6.3/Kernel.html#method-i-raise)
# and `rescue` statements in `begin ... end` blocks.
# [Exception](Exception) objects carry information
# about the exception – its type (the exception’s class name), an optional
# descriptive string, and optional traceback information.
# [Exception](Exception) subclasses may add additional
# information like
# [NameError\#name](https://ruby-doc.org/core-2.6.3/NameError.html#method-i-name)
# .
#
# Programs may make subclasses of
# [Exception](Exception), typically of
# [StandardError](https://ruby-doc.org/core-2.6.3/StandardError.html) or
# [RuntimeError](https://ruby-doc.org/core-2.6.3/RuntimeError.html), to
# provide custom classes and add additional information. See the subclass
# list below for defaults for `raise` and `rescue` .
#
# When an exception has been raised but not yet handled (in `rescue`,
# `ensure`, `at_exit` and `END` blocks) the global variable `$!` will
# contain the current exception and `$@` contains the current exception’s
# backtrace.
#
# It is recommended that a library should have one subclass of
# [StandardError](https://ruby-doc.org/core-2.6.3/StandardError.html) or
# [RuntimeError](https://ruby-doc.org/core-2.6.3/RuntimeError.html) and
# have specific exception types inherit from it. This allows the user to
# rescue a generic exception type to catch all exceptions the library may
# raise even if future versions of the library add new exception
# subclasses.
#
# For example:
#
# ```ruby
# class MyLibrary
#   class Error < RuntimeError
#   end
#
#   class WidgetError < Error
#   end
#
#   class FrobError < Error
#   end
#
# end
# ```
#
# To handle both WidgetError and FrobError the library user can rescue
# MyLibrary::Error.
#
# The built-in subclasses of [Exception](Exception)
# are:
#
#   - [NoMemoryError](https://ruby-doc.org/core-2.6.3/NoMemoryError.html)
#
#   - [ScriptError](https://ruby-doc.org/core-2.6.3/ScriptError.html)
#
#       - [LoadError](https://ruby-doc.org/core-2.6.3/LoadError.html)
#
#       - [NotImplementedError](https://ruby-doc.org/core-2.6.3/NotImplementedError.html)
#
#       - [SyntaxError](https://ruby-doc.org/core-2.6.3/SyntaxError.html)
#
#   - [SecurityError](https://ruby-doc.org/core-2.6.3/SecurityError.html)
#
#   - [SignalException](https://ruby-doc.org/core-2.6.3/SignalException.html)
#
#       - [Interrupt](https://ruby-doc.org/core-2.6.3/Interrupt.html)
#
#   - [StandardError](https://ruby-doc.org/core-2.6.3/StandardError.html)
#     -- default for `rescue`
#
#       - [ArgumentError](https://ruby-doc.org/core-2.6.3/ArgumentError.html)
#
#           - [UncaughtThrowError](https://ruby-doc.org/core-2.6.3/UncaughtThrowError.html)
#
#       - [EncodingError](https://ruby-doc.org/core-2.6.3/EncodingError.html)
#
#       - [FiberError](https://ruby-doc.org/core-2.6.3/FiberError.html)
#
#       - [IOError](https://ruby-doc.org/core-2.6.3/IOError.html)
#
#           - [EOFError](https://ruby-doc.org/core-2.6.3/EOFError.html)
#
#       - [IndexError](https://ruby-doc.org/core-2.6.3/IndexError.html)
#
#           - [KeyError](https://ruby-doc.org/core-2.6.3/KeyError.html)
#
#           - [StopIteration](https://ruby-doc.org/core-2.6.3/StopIteration.html)
#
#       - [LocalJumpError](https://ruby-doc.org/core-2.6.3/LocalJumpError.html)
#
#       - [NameError](https://ruby-doc.org/core-2.6.3/NameError.html)
#
#           - [NoMethodError](https://ruby-doc.org/core-2.6.3/NoMethodError.html)
#
#       - [RangeError](https://ruby-doc.org/core-2.6.3/RangeError.html)
#
#           - [FloatDomainError](https://ruby-doc.org/core-2.6.3/FloatDomainError.html)
#
#       - [RegexpError](https://ruby-doc.org/core-2.6.3/RegexpError.html)
#
#       - [RuntimeError](https://ruby-doc.org/core-2.6.3/RuntimeError.html)
#         -- default for `raise`
#
#           - [FrozenError](https://ruby-doc.org/core-2.6.3/FrozenError.html)
#
#       - [SystemCallError](https://ruby-doc.org/core-2.6.3/SystemCallError.html)
#
#           - Errno::\*
#
#       - [ThreadError](https://ruby-doc.org/core-2.6.3/ThreadError.html)
#
#       - [TypeError](https://ruby-doc.org/core-2.6.3/TypeError.html)
#
#       - [ZeroDivisionError](https://ruby-doc.org/core-2.6.3/ZeroDivisionError.html)
#
#   - [SystemExit](https://ruby-doc.org/core-2.6.3/SystemExit.html)
#
#   - [SystemStackError](https://ruby-doc.org/core-2.6.3/SystemStackError.html)
#
#   - fatal – impossible to rescue
class Exception < Object
  def self.to_tty?: () -> bool
  def self.exception: (?String msg) -> Exception
  def ==: (untyped arg0) -> bool
  # Returns any backtrace associated with the exception. The backtrace is an
  # array of strings, each containing either “filename:lineNo: in \`method”‘
  # or “filename:lineNo.”
  #
  # ```ruby
  # def a
  #   raise "boom"
  # end
  #
  # def b
  #   a()
  # end
  #
  # begin
  #   b()
  # rescue => detail
  #   print detail.backtrace.join("\n")
  # end
  # ```
  #
  # *produces:*
  #
  #     prog.rb:2:in `a'
  #     prog.rb:6:in `b'
  #     prog.rb:10
  def backtrace: () -> ::Array[String]?
  # Returns any backtrace associated with the exception. This method is
  # similar to
  # [\#backtrace](Exception.downloaded.ruby_doc#method-i-backtrace), but
  # the backtrace is an array of
  # [Thread::Backtrace::Location](https://ruby-doc.org/core-2.6.3/Thread/Backtrace/Location.html)
  # .
  #
  # Now, this method is not affected by
  # [\#set\_backtrace](Exception.downloaded.ruby_doc#method-i-set_backtrace)
  # .
  def backtrace_locations: () -> ::Array[Thread::Backtrace::Location]?
  # Returns the previous exception ($\!) at the time this exception was
  # raised. This is useful for wrapping exceptions and retaining the
  # original exception information.
  def cause: () -> Exception?
  def exception: () -> self
               | (String arg0) -> Exception
  def initialize: (?String arg0) -> void
  # Return this exception’s class name and message.
  def inspect: () -> String
  # Returns the result of invoking `exception.to_s` . Normally this returns
  # the exception’s message or name.
  def message: () -> String
  def set_backtrace: (String | ::Array[String] arg0) -> ::Array[String]
  # Returns exception’s message (or the name of the exception if no message
  # is set).
  def to_s: () -> String
  def full_message: (?highlight: bool, ?order: :top | :bottom) -> String
end