@@ -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 )
169
+ def next_occurrences ( num , from = nil , spans = false )
170
170
from = TimeUtil . match_zone ( from , start_time ) || TimeUtil . now ( start_time )
171
- enumerate_occurrences ( from + 1 , nil ) . take ( num )
171
+ enumerate_occurrences ( from + 1 , nil , spans ) . take ( num )
172
172
end
173
173
174
174
# The next occurrence after now (overridable)
175
- def next_occurrence ( from = nil )
175
+ def next_occurrence ( from = nil , spans = false )
176
176
from = TimeUtil . match_zone ( from , start_time ) || TimeUtil . now ( start_time )
177
- enumerate_occurrences ( from + 1 , nil ) . next
177
+ enumerate_occurrences ( from + 1 , nil , spans ) . 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 )
198
+ def remaining_occurrences ( from = nil , spans = false )
199
199
require_terminating_rules
200
200
from ||= TimeUtil . now ( @start_time )
201
- enumerate_occurrences ( from ) . to_a
201
+ enumerate_occurrences ( from , nil , spans ) . to_a
202
202
end
203
203
204
204
# Returns an enumerator for all remaining occurrences
205
- def remaining_occurrences_enumerator ( from = nil )
205
+ def remaining_occurrences_enumerator ( from = nil , spans = false )
206
206
from ||= TimeUtil . now ( @start_time )
207
- enumerate_occurrences ( from )
207
+ enumerate_occurrences ( from , nil , spans )
208
208
end
209
209
210
210
# Occurrences between two times
211
- def occurrences_between ( begin_time , closing_time )
212
- enumerate_occurrences ( begin_time , closing_time ) . to_a
211
+ def occurrences_between ( begin_time , closing_time , spans = false )
212
+ enumerate_occurrences ( begin_time , closing_time , spans ) . 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 )
217
- enumerate_occurrences ( begin_time , closing_time ) . next
216
+ def occurs_between? ( begin_time , closing_time , spans = false )
217
+ enumerate_occurrences ( begin_time , closing_time , spans ) . next
218
218
true
219
219
rescue StopIteration
220
220
false
@@ -404,25 +404,29 @@ def reset
404
404
# Find all of the occurrences for the schedule between opening_time
405
405
# and closing_time
406
406
# Iteration is unrolled in pairs to skip duplicate times in end of DST
407
- def enumerate_occurrences ( opening_time , closing_time = nil , &block )
407
+ def enumerate_occurrences ( opening_time , closing_time = nil , spans = false , &block )
408
408
opening_time = TimeUtil . match_zone ( opening_time , start_time )
409
409
closing_time = TimeUtil . match_zone ( closing_time , start_time )
410
410
opening_time += start_time . subsec - opening_time . subsec rescue 0
411
411
opening_time = start_time if opening_time < start_time
412
412
Enumerator . new do |yielder |
413
413
reset
414
- t1 = full_required? ? start_time : realign ( opening_time )
414
+ t1 = full_required? || spans ? start_time : realign ( opening_time )
415
415
loop do
416
416
break unless ( t0 = next_time ( t1 , closing_time ) )
417
417
break if closing_time && t0 > closing_time
418
- yielder << ( block_given? ? block . call ( t0 ) : t0 ) if t0 >= opening_time
418
+ if ( spans ? t0 . end_time : t0 ) >= opening_time
419
+ yielder << ( block_given? ? block . call ( t0 ) : t0 )
420
+ end
419
421
break unless ( t1 = next_time ( t0 + 1 , closing_time ) )
420
422
break if closing_time && t1 > closing_time
421
423
if TimeUtil . same_clock? ( t0 , t1 ) && recurrence_rules . any? ( &:dst_adjust? )
422
424
wind_back_dst
423
425
next ( t1 += 1 )
424
426
end
425
- yielder << ( block_given? ? block . call ( t1 ) : t1 ) if t1 >= opening_time
427
+ if ( spans ? t1 . end_time : t1 ) >= opening_time
428
+ yielder << ( block_given? ? block . call ( t1 ) : t1 )
429
+ end
426
430
next ( t1 += 1 )
427
431
end
428
432
end
0 commit comments