lib/byebug/commands/condition.rb in byebug-3.5.1 vs lib/byebug/commands/condition.rb in byebug-4.0.0

- old
+ new

@@ -1,5 +1,7 @@ +require 'byebug/command' + module Byebug # # Implements conditions on breakpoints. # # Adds the ability to stop on breakpoints only under certain conditions. @@ -10,39 +12,41 @@ def regexp /^\s* cond(?:ition)? (?:\s+(\d+)(?:\s+(.*))?)? \s*$/x end def execute - return puts(ConditionCommand.help) unless @match[1] + return puts(self.class.help) unless @match[1] - breakpoints = Byebug.breakpoints.sort_by { |b| b.id } - return errmsg('No breakpoints have been set') unless breakpoints.any? + breakpoints = Byebug.breakpoints.sort_by(&:id) + return errmsg(pr('condition.errors.no_breakpoints')) if breakpoints.empty? pos, err = get_int(@match[1], 'Condition', 1) return errmsg(err) if err breakpoint = breakpoints.find { |b| b.id == pos } - return errmsg('Invalid breakpoint id. Use "info breakpoint" to find ' \ - 'out the correct id') unless breakpoint + return errmsg(pr('break.errors.no_breakpoint')) unless breakpoint - return errmsg("Incorrect expression \"#{@match[2]}\", " \ - 'breakpoint not changed') unless syntax_valid?(@match[2]) + unless syntax_valid?(@match[2]) + return errmsg(pr('break.errors.not_changed', expr: @match[2])) + end breakpoint.expr = @match[2] end class << self def names %w(condition) end def description - %(cond[ition] <n>[ expr] + prettify <<-EOD + cond[ition] <n>[ expr] Specify breakpoint number <n> to break only if <expr> is true. <n> is an integer and <expr> is an expression to be evaluated whenever breakpoint <n> is reached. If no expression is specified, the - condition is removed.) + condition is removed. + EOD end end end end