使用pry-byebug设置条件断点

时间:2017-01-04 23:14:30

标签: ruby pry byebug

给出以下代码:

require 'pry-byebug'

10.times.with_index do |i|
  binding.pry
  puts i
end

我想在i == 5内“循环直到pry-byebug然后休息”。从运行help break开始,您似乎可以通过“breakpoint#”或“line#”来识别断点。你似乎也可以使用条件,但是我没有让它工作:

尝试在第#:

行设置断点
$  ruby foo.rb

From: /Users/max/Dropbox/work/tmp/pry_debug/foo.rb @ line 5 :

    1: require 'pry-byebug'
    2:
    3: 10.times.with_index do |i|
    4:   binding.pry
 => 5:   puts i
    6: end

[1] pry(main)> break foo.rb:5 if i == 5

  Breakpoint 1: /Users/max/Dropbox/work/tmp/pry_debug/foo.rb @ 5 (Enabled) Condition: i == 5


    2:
    3: 10.times.with_index do |i|
    4:   binding.pry
 => 5:   puts i
    6: end


[2] pry(main)> continue
0

From: /Users/max/Dropbox/work/tmp/pry_debug/foo.rb @ line 5 :

    1: require 'pry-byebug'
    2:
    3: 10.times.with_index do |i|
    4:   binding.pry
 => 5:   puts i
    6: end

[2] pry(main)> i
=> 1

首先设置断点然后将条件放在断点上:

➜  ~/D/w/t/pry_debug  ruby foo.rb

From: /Users/max/Dropbox/work/tmp/pry_debug/foo.rb @ line 5 :

    1: require 'pry-byebug'
    2:
    3: 10.times.with_index do |i|
    4:   binding.pry
 => 5:   puts i
    6: end

[1] pry(main)> break foo.rb:15

  Breakpoint 1: /Users/max/Dropbox/work/tmp/pry_debug/foo.rb @ 15 (Enabled)



[2] pry(main)> break --condition 1 i == 5
[3] pry(main)> c
0

From: /Users/max/Dropbox/work/tmp/pry_debug/foo.rb @ line 5 :

    1: require 'pry-byebug'
    2:
    3: 10.times.with_index do |i|
    4:   binding.pry
 => 5:   puts i
    6: end

[3] pry(main)> i
=> 1

正如您所看到的,pry-byebug在两种情况下都不尊重这种情况,因为它太早停止了。我如何让它工作?

2 个答案:

答案 0 :(得分:6)

我认为一种简单的方法是在您的代码中执行此操作:

require 'pry-byebug'

10.times.with_index do |i|
  binding.pry if i == 5
  puts i
end

或者,如果您想停在异常处,可以执行以下操作:

require 'pry-byebug'

10.times.with_index do |i|
  puts i rescue binding.pry # if the puts command throws an exception, you'll be taken to pry
end

答案 1 :(得分:1)

从循环内部删除binding.pry并将其放在10.times之前:

binding.pry
10.times.with_index do |i|

然后运行代码。当它到达断点时,然后使用您想要的条件和continue设置新的断点。

返回实际代码。不要这样做:

10.times.with_index do |i|

相反,这将做几乎相同的事情,但它更简单:

10.times do |i|

这是Ruby正在做的事情:

>> 2.times.with_index.to_a
[
  [0] [
    [0] 0,
    [1] 0
  ],
  [1] [
    [0] 1,
    [1] 1
  ]
]

VS。

>> 2.times.to_a
[
  [0] 0,
  [1] 1
]

第一个是传递[0,0][1,1]等数组,所以为了正确,您的块参数必须类似于:

10.times.with_index do |i, j|

第二个只通过当前"次"值,导致更简单的代码。