@@ -166,15 +166,15 @@ def each_occurrence(&block)
166166 end
167167
168168 # The next n occurrences after now
169- def next_occurrences ( num , from = nil , spans = false )
169+ def next_occurrences ( num , from = nil , options = { } )
170170 from = TimeUtil . match_zone ( from , start_time ) || TimeUtil . now ( start_time )
171- enumerate_occurrences ( from + 1 , nil , spans ) . take ( num )
171+ enumerate_occurrences ( from + 1 , nil , options ) . take ( num )
172172 end
173173
174174 # The next occurrence after now (overridable)
175- def next_occurrence ( from = nil , spans = false )
175+ def next_occurrence ( from = nil , options = { } )
176176 from = TimeUtil . match_zone ( from , start_time ) || TimeUtil . now ( start_time )
177- enumerate_occurrences ( from + 1 , nil , spans ) . next
177+ enumerate_occurrences ( from + 1 , nil , options ) . next
178178 rescue StopIteration
179179 nil
180180 end
@@ -195,26 +195,26 @@ def previous_occurrences(num, from)
195195 end
196196
197197 # The remaining occurrences (same requirements as all_occurrences)
198- def remaining_occurrences ( from = nil , spans = false )
198+ def remaining_occurrences ( from = nil , options = { } )
199199 require_terminating_rules
200200 from ||= TimeUtil . now ( @start_time )
201- enumerate_occurrences ( from , nil , spans ) . to_a
201+ enumerate_occurrences ( from , nil , options ) . to_a
202202 end
203203
204204 # Returns an enumerator for all remaining occurrences
205- def remaining_occurrences_enumerator ( from = nil , spans = false )
205+ def remaining_occurrences_enumerator ( from = nil , options = { } )
206206 from ||= TimeUtil . now ( @start_time )
207- enumerate_occurrences ( from , nil , spans )
207+ enumerate_occurrences ( from , nil , options )
208208 end
209209
210210 # Occurrences between two times
211- def occurrences_between ( begin_time , closing_time , spans = false )
212- enumerate_occurrences ( begin_time , closing_time , spans ) . to_a
211+ def occurrences_between ( begin_time , closing_time , options = { } )
212+ enumerate_occurrences ( begin_time , closing_time , options ) . to_a
213213 end
214214
215215 # Return a boolean indicating if an occurrence falls between two times
216- def occurs_between? ( begin_time , closing_time , spans = false )
217- enumerate_occurrences ( begin_time , closing_time , spans ) . next
216+ def occurs_between? ( begin_time , closing_time , options = { } )
217+ enumerate_occurrences ( begin_time , closing_time , options ) . next
218218 true
219219 rescue StopIteration
220220 false
@@ -226,7 +226,7 @@ def occurs_between?(begin_time, closing_time, spans = false)
226226 # occurrences at the end of the range since none of their duration
227227 # intersects the range.
228228 def occurring_between? ( opening_time , closing_time )
229- occurs_between? ( opening_time , closing_time , true )
229+ occurs_between? ( opening_time , closing_time , :spans => true )
230230 end
231231
232232 # Return a boolean indicating if an occurrence falls on a certain date
@@ -402,12 +402,12 @@ def reset
402402 # Find all of the occurrences for the schedule between opening_time
403403 # and closing_time
404404 # Iteration is unrolled in pairs to skip duplicate times in end of DST
405- def enumerate_occurrences ( opening_time , closing_time = nil , spans = false , &block )
405+ def enumerate_occurrences ( opening_time , closing_time = nil , options = { } , &block )
406406 opening_time = TimeUtil . match_zone ( opening_time , start_time )
407407 closing_time = TimeUtil . match_zone ( closing_time , start_time )
408408 opening_time += start_time . subsec - opening_time . subsec rescue 0
409409 opening_time = start_time if opening_time < start_time
410- spans = false if duration = = 0
410+ spans = options [ :spans ] == true && duration ! = 0
411411 Enumerator . new do |yielder |
412412 reset
413413 t1 = full_required? ? start_time : realign ( ( spans ? opening_time - duration : opening_time ) )
0 commit comments