1
0
Fork 0
mirror of https://github.com/ruby/ruby.git synced 2022-11-09 12:17:21 -05:00

* sample/timeout.rb: split from lib/timeout.rb.

git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@26877 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
nobu 2010-03-11 21:37:16 +00:00
parent ebfe278914
commit 831eb93069
4 changed files with 48 additions and 23 deletions

42
sample/timeout.rb Normal file
View file

@ -0,0 +1,42 @@
require 'timeout'
def progress(n = 5)
n.times {|i| print i; STDOUT.flush; sleep 1; i+= 1}
puts "never reach"
end
p timeout(5) {
45
}
p timeout(5, TimeoutError) {
45
}
p timeout(nil) {
54
}
p timeout(0) {
54
}
begin
timeout(5) {progress}
rescue => e
puts e.message
end
begin
timeout(3) {
begin
timeout(5) {progress}
rescue => e
puts "never reach"
end
}
rescue => e
puts e.message
end
class MyTimeout < StandardError
end
begin
timeout(2, MyTimeout) {progress}
rescue MyTimeout => e
puts e.message
end