em-timers
helper methods for timers in EventMachine
examples:
# Once per hour, starting now. Note the :now symbol must be passed for your block to be called immediately. EM.do_hourly(:starting => :now) { puts “drink a beer” }
# Once per day, starting in 1 day. EM.do_daily { puts “take a shower” }
# Once per week, starting in 10 hours EM.do_weekly(:starting => 10.hours.from_now) { puts “take out the garbage” }
# Once per month, starting at this time tomorrow. EM.do_monthly(:starting => 1.day.from_now) { puts “pay the bills” }
# Or you can simply pass a number of seconds til starting EM.do_monthly(:starting => 2592000) { puts “pay the bills, in seconds!” }
# Leveraging the Chronic time parsing library. em-timers knows if you have required # Chronic and uses it to parse strings if you have. Otherwise, it uses Time.parse. # # Every 2 hours, starting next Tuesday at 9AM. require ‘chronic’ EM.do(:every => 2.hours, :starting => ‘next tuesday at 9am’) { puts “go pee” }
# You can add up units of time as well EM.do(:every => 1.minutes + 3.seconds) { puts “hi!” }
TODO:
Maintain a list of task signatures and their associated timer signatures so tasks can be canceled.
[email protected] yakischloba on Freenode #eventmachine