lib/byebug/commands/catch.rb
# frozen_string_literal: true require_relative "../command" require_relative "../helpers/eval" module Byebug # # Implements exception catching. # # Enables the user to catch unhandled assertion when they happen. # class CatchCommand < Command include Helpers::EvalHelper self.allow_in_post_mortem = true def self.regexp /^\s* cat(?:ch)? (?:\s+(\S+))? (?:\s+(off))? \s*$/x end def self.description <<-DESCRIPTION cat[ch][ (off|<exception>[ off])] #{short_description} catch -- lists catchpoints catch off -- deletes all catchpoints catch <exception> -- enables handling <exception> catch <exception> off -- disables handling <exception> DESCRIPTION end def self.short_description "Handles exception catchpoints" end def execute return info unless @match[1] return @match[1] == "off" ? clear : add(@match[1]) unless @match[2] return errmsg pr("catch.errors.off", off: cmd) unless @match[2] == "off" remove(@match[1]) end private def remove(exception) return errmsg pr("catch.errors.not_found", exception: exception) unless Byebug.catchpoints.member?(exception) puts pr("catch.removed", exception: exception) Byebug.catchpoints.delete(exception) end def add(exception) errmsg pr("catch.errors.not_class", class: exception) if warning_eval(exception.is_a?(Class).to_s) puts pr("catch.added", exception: exception) Byebug.add_catchpoint(exception) end def clear Byebug.catchpoints.clear if confirm(pr("catch.confirmations.delete_all")) end def info if Byebug.catchpoints && !Byebug.catchpoints.empty? Byebug.catchpoints.each_key do |exception| puts("#{exception}: #{exception.is_a?(Class)}") end else puts "No exceptions set to be caught." end end end end