Module: Tot::Utils

Defined in:
lib/tot.rb

Overview

}}}

Class Method Summary collapse

Class Method Details

.datetime_filter(buf) ⇒ Object

{{{



96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
# File 'lib/tot.rb', line 96

def datetime_filter(buf) #{{{
  today = DateTime.now
  ret = nil
  case buf
  when /^(今日)/
    ret = today
  when /^(明日|あした|あす)/
    ret = today + 1
  when /^(明後日|あさって)/
    ret = today + 2
  when /^しあさって/
    ret = today + 3
  when /^(日|月|火|水|木|金|土)曜(日)?/
    # 次の○曜日
    date_offset = ([ '', '', '', '', '', '', '' ].index($1) - today.wday + 7) % 7
    date_offset += 7 if date_offset == 0
    ret = today + date_offset
  when /^([0-9]+\/[0-9]+\/[0-9]+)/# yyyy/mm/dd
    ret = DateTime.parse($1)
  when /^([0-9]+\/[0-9]+)/# mm/dd
    date = DateTime.parse($1)
    # 過去の日付だったら来年にする
    while date < today
      date = date >> 12
    end
    ret = date
  when /^([0-9]+)/# mmddd
    datestr = $1
    case datestr.length
    when 2
      # 12   => 1/2
      datestr = datestr.slice(0..0) + "/" + datestr.slice(1..1)
    when 3
      # 123  => 1/23 ※ 12/3 の可能性もあるけどそうはしない
      datestr = datestr.slice(0..0) + "/" + datestr.slice(1..2)
    when 4
      # 1230 => 12/30
      datestr = datestr.slice(0..1) + "/" + datestr.slice(2..3)
    else
      raise ArgumentError , "不正な値です"
    end
    date = DateTime.parse(datestr)
    # 過去の日付だったら来年にする
    while date < today
      date = date >> 12
    end
    ret = date
  end
  ret
end