@@ -166,15 +166,15 @@ def each_occurrence(&block)
166
166
end
167
167
168
168
# The next n occurrences after now
169
- def next_occurrences ( num , from = nil , spans = false )
169
+ def next_occurrences ( num , from = nil , options = { } )
170
170
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 )
172
172
end
173
173
174
174
# The next occurrence after now (overridable)
175
- def next_occurrence ( from = nil , spans = false )
175
+ def next_occurrence ( from = nil , options = { } )
176
176
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
178
178
rescue StopIteration
179
179
nil
180
180
end
@@ -195,26 +195,26 @@ def previous_occurrences(num, from)
195
195
end
196
196
197
197
# The remaining occurrences (same requirements as all_occurrences)
198
- def remaining_occurrences ( from = nil , spans = false )
198
+ def remaining_occurrences ( from = nil , options = { } )
199
199
require_terminating_rules
200
200
from ||= TimeUtil . now ( @start_time )
201
- enumerate_occurrences ( from , nil , spans ) . to_a
201
+ enumerate_occurrences ( from , nil , options ) . to_a
202
202
end
203
203
204
204
# Returns an enumerator for all remaining occurrences
205
- def remaining_occurrences_enumerator ( from = nil , spans = false )
205
+ def remaining_occurrences_enumerator ( from = nil , options = { } )
206
206
from ||= TimeUtil . now ( @start_time )
207
- enumerate_occurrences ( from , nil , spans )
207
+ enumerate_occurrences ( from , nil , options )
208
208
end
209
209
210
210
# 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
213
213
end
214
214
215
215
# 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
218
218
true
219
219
rescue StopIteration
220
220
false
@@ -226,7 +226,7 @@ def occurs_between?(begin_time, closing_time, spans = false)
226
226
# occurrences at the end of the range since none of their duration
227
227
# intersects the range.
228
228
def occurring_between? ( opening_time , closing_time )
229
- occurs_between? ( opening_time , closing_time , true )
229
+ occurs_between? ( opening_time , closing_time , :spans => true )
230
230
end
231
231
232
232
# Return a boolean indicating if an occurrence falls on a certain date
@@ -402,12 +402,12 @@ def reset
402
402
# Find all of the occurrences for the schedule between opening_time
403
403
# and closing_time
404
404
# 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 )
406
406
opening_time = TimeUtil . match_zone ( opening_time , start_time )
407
407
closing_time = TimeUtil . match_zone ( closing_time , start_time )
408
408
opening_time += start_time . subsec - opening_time . subsec rescue 0
409
409
opening_time = start_time if opening_time < start_time
410
- spans = false if duration = = 0
410
+ spans = options [ :spans ] == true && duration ! = 0
411
411
Enumerator . new do |yielder |
412
412
reset
413
413
t1 = full_required? ? start_time : realign ( ( spans ? opening_time - duration : opening_time ) )
0 commit comments