Skip to content

Commit

Permalink
Deprecate measure :on and navigate to use measure on
Browse files Browse the repository at this point in the history
  • Loading branch information
tompng committed May 26, 2024
1 parent e2d0fad commit f860252
Show file tree
Hide file tree
Showing 4 changed files with 66 additions and 37 deletions.
2 changes: 1 addition & 1 deletion README.md
Original file line number Diff line number Diff line change
Expand Up @@ -149,7 +149,7 @@ Debugging
Misc
edit Open a file or source location.
measure `measure` enables the mode to measure processing time. `measure :off` disables it.
measure `measure` enables the mode to measure processing time. `measure off` disables it.
Context
show_doc Enter the mode to look up RI documents.
Expand Down
39 changes: 26 additions & 13 deletions lib/irb/command/measure.rb
Original file line number Diff line number Diff line change
Expand Up @@ -3,10 +3,8 @@ module IRB

module Command
class Measure < Base
include RubyArgsExtractor

category "Misc"
description "`measure` enables the mode to measure processing time. `measure :off` disables it."
description "`measure` enables the mode to measure processing time. `measure off` disables it."

def initialize(*args)
super(*args)
Expand All @@ -17,28 +15,43 @@ def execute(arg)
warn 'Configure IRB.conf[:MEASURE_PROC] to add custom measure methods.'
return
end
args, kwargs = ruby_args(arg)
execute_internal(*args, **kwargs)

if arg.empty?
execute_internal(nil, nil)
elsif arg.start_with? ':'
# Legacy style `measure :sym`, `measure :sym, :sym`
type, arg_val = arg.split(/,\s*/, 2).map { |v| v.sub(/\A:/, '') }
warn "`measure #{arg}` is deprecated. Use `measure #{[type, arg_val].compact.join(' ')}` instead."
execute_internal(type.to_sym, arg_val)
else
type, arg_val = arg.split(/\s+/, 2)
execute_internal(type&.to_sym, arg_val)
end
end

def execute_internal(type = nil, arg = nil)
def execute_internal(type, arg)
# Please check IRB.init_config in lib/irb/init.rb that sets
# IRB.conf[:MEASURE_PROC] to register default "measure" methods,
# "measure :time" (abbreviated as "measure") and "measure :stackprof".
# "measure time" (abbreviated as "measure") and "measure stackprof".

case type
when :off
IRB.unset_measure_callback(arg)
IRB.unset_measure_callback(arg&.to_sym)
when :list
IRB.conf[:MEASURE_CALLBACKS].each do |type_name, _, arg_val|
puts "- #{type_name}" + (arg_val ? "(#{arg_val.inspect})" : '')
end
when :on
added = IRB.set_measure_callback(arg)
puts "#{added[0]} is added." if added
else
added = IRB.set_measure_callback(type, arg)
puts "#{added[0]} is added." if added
type, arg = arg&.to_sym, nil if type == :on

measure_methods = IRB.conf[:MEASURE_PROC].keys.map(&:downcase)
if type && !measure_methods.include?(type)
puts "Measure method `#{type}` not found."
puts "Available measure methods: %w[#{measure_methods.join(' ')}]."
else
added = IRB.set_measure_callback(type&.to_sym, arg)
puts "#{added[0]} is added." if added
end
end
nil
end
Expand Down
14 changes: 2 additions & 12 deletions lib/irb/init.rb
Original file line number Diff line number Diff line change
Expand Up @@ -204,19 +204,9 @@ def IRB.set_measure_callback(type = nil, arg = nil, &block)
added = [type_sym, IRB.conf[:MEASURE_PROC][type_sym], arg]
end
elsif IRB.conf[:MEASURE_PROC][:CUSTOM]
added = [:CUSTOM, IRB.conf[:MEASURE_PROC][:CUSTOM], arg]
elsif block_given?
added = [:BLOCK, block, arg]
found = IRB.conf[:MEASURE_CALLBACKS].find{ |m| m[0] == added[0] && m[2] == added[2] }
if found
found[1] = block
return added
else
IRB.conf[:MEASURE_CALLBACKS] << added
return added
end
added = [:CUSTOM, IRB.conf[:MEASURE_PROC][:CUSTOM], nil]
else
added = [:TIME, IRB.conf[:MEASURE_PROC][:TIME], arg]
added = [:TIME, IRB.conf[:MEASURE_PROC][:TIME], nil]
end
if added
IRB.conf[:MEASURE] = true
Expand Down
48 changes: 37 additions & 11 deletions test/irb/test_command.rb
Original file line number Diff line number Diff line change
Expand Up @@ -235,11 +235,11 @@ def test_measure
out, err = execute_lines(
"measure\n",
"3\n",
"measure :off\n",
"measure off\n",
"3\n",
"measure :on\n",
"measure on\n",
"3\n",
"measure :off\n",
"measure off\n",
"3\n",
conf: conf,
main: c
Expand Down Expand Up @@ -292,7 +292,7 @@ def test_measure_enabled_by_rc

out, err = execute_lines(
"3\n",
"measure :off\n",
"measure off\n",
"3\n",
conf: conf,
)
Expand All @@ -317,7 +317,7 @@ def test_measure_enabled_by_rc_with_custom

out, err = execute_lines(
"3\n",
"measure :off\n",
"measure off\n",
"3\n",
conf: conf,
)
Expand All @@ -342,7 +342,7 @@ def test_measure_with_custom
"3\n",
"measure\n",
"3\n",
"measure :off\n",
"measure off\n",
"3\n",
conf: conf
)
Expand All @@ -368,19 +368,19 @@ def test_measure_toggle
}
}
out, err = execute_lines(
"measure :foo, :arg\n",
"measure foo arg\n",
"1\n",
"measure :on, :bar\n",
"measure on bar\n",
"2\n",
"measure :off, :foo\n",
"measure off foo\n",
"3\n",
"measure :off, :bar\n",
"measure off bar\n",
"4\n",
conf: conf
)

assert_empty err
assert_match(/\AFOO is added\.\n=> nil\nfoo\(:arg\)\n=> 1\nBAR is added\.\n=> nil\nbar\(nil\)\nfoo\(:arg\)\n=> 2\n=> nil\nbar\(nil\)\n=> 3\n=> nil\n=> 4\n/, out)
assert_match(/\AFOO is added\.\n=> nil\nfoo\("arg"\)\n=> 1\nBAR is added\.\n=> nil\nbar\(nil\)\nfoo\("arg"\)\n=> 2\n=> nil\nbar\(nil\)\n=> 3\n=> nil\n=> 4\n/, out)
end

def test_measure_with_proc_warning
Expand Down Expand Up @@ -408,6 +408,32 @@ def test_measure_with_proc_warning
assert_match(/\A=> 3\n=> nil\n=> 3\n/, out)
assert_empty(c.class_variables)
end

def test_legacy_measure_warning
conf = {
MEASURE_PROC: {
FOO: proc {},
BAR: proc {},
}
}
out, err = execute_lines(
"measure :foo\n",
"measure :on, :bar\n",
conf: conf
)
assert_match(/FOO is added/, out)
assert_match(/BAR is added/, out)
assert_match(/`measure :foo` is deprecated. Use `measure foo`/, err)
assert_match(/`measure :on, :bar` is deprecated. Use `measure on bar`/, err)
end

def test_unknown_method
out, err = execute_lines("measure foo\n", "measure on bar\n")
assert_empty(err)
assert_match(/`foo` not found/, out)
assert_match(/`bar` not found/, out)
assert_match(/time stackprof/, out)
end
end

class IrbSourceTest < CommandTestCase
Expand Down

0 comments on commit f860252

Please sign in to comment.