Module: Logger::Period

Included in:
LogDevice
Defined in:
lib/logger.rb

Constant Summary collapse

SiD =
24 * 60 * 60

Class Method Summary collapse

Class Method Details

.next_rotate_time(now, shift_age) ⇒ Object


534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
# File 'lib/logger.rb', line 534

def next_rotate_time(now, shift_age)
  case shift_age
  when /^daily$/
    t = Time.mktime(now.year, now.month, now.mday) + SiD
  when /^weekly$/
    t = Time.mktime(now.year, now.month, now.mday) + SiD * (7 - now.wday)
  when /^monthly$/
    t = Time.mktime(now.year, now.month, 1) + SiD * 31
    mday = (1 if t.mday > 1)
  else
    return now
  end
  if mday or t.hour.nonzero? or t.min.nonzero? or t.sec.nonzero?
    t = Time.mktime(t.year, t.month, mday || (t.mday + (t.hour > 12 ? 1 : 0)))
  end
  t
end

.previous_period_end(now, shift_age) ⇒ Object


552
553
554
555
556
557
558
559
560
561
562
563
564
# File 'lib/logger.rb', line 552

def previous_period_end(now, shift_age)
  case shift_age
  when /^daily$/
    t = Time.mktime(now.year, now.month, now.mday) - SiD / 2
  when /^weekly$/
    t = Time.mktime(now.year, now.month, now.mday) - (SiD * (now.wday + 1) + SiD / 2)
  when /^monthly$/
    t = Time.mktime(now.year, now.month, 1) - SiD / 2
  else
    return now
  end
  Time.mktime(t.year, t.month, t.mday, 23, 59, 59)
end