Module: Wareki::Utils

Defined in:
lib/wareki/utils.rb

Class Method Summary collapse

Class Method Details

._to_date(d) ⇒ Object



126
127
128
129
130
131
132
133
134
# File 'lib/wareki/utils.rb', line 126

def _to_date(d)
  if d.kind_of? ::Date
    d # nothing to do
  elsif d.kind_of?(Time)
    d.to_date
  else
    ::Date.jd(d.to_i)
  end
end

._to_jd(d) ⇒ Object



136
137
138
139
140
141
142
143
144
# File 'lib/wareki/utils.rb', line 136

def _to_jd(d)
  if d.kind_of? ::Date
    d.jd
  elsif d.kind_of?(Time)
    d.to_date.jd
  else
    d.to_i
  end
end

.alt_month_name(month) ⇒ Object



122
123
124
# File 'lib/wareki/utils.rb', line 122

def alt_month_name(month)
  ALT_MONTH_NAME[month - 1]
end

.alt_month_name_to_i(name) ⇒ Object



117
118
119
120
# File 'lib/wareki/utils.rb', line 117

def alt_month_name_to_i(name)
  i = ALT_MONTH_NAME.index(name) or return false
  i + 1
end

.find_date_ary(d) ⇒ Object



146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
# File 'lib/wareki/utils.rb', line 146

def find_date_ary(d)
  d = _to_date(d).new_start(::Date::GREGORIAN)
  if d.jd >= GREGORIAN_START
    return [d.year, d.month, d.day, false]
  end

  yobj = find_year(d) or raise UnsupportedDateRange, "Unsupported date: #{d.inspect}"
  month = 0
  is_leap = false
  if yobj.month_starts.last <= d.jd
    month = yobj.month_starts.count
  else
    month = yobj.month_starts.find_index {|m| d.jd <= (m - 1) }
  end
  month_start = yobj.month_starts[month-1]
  is_leap = (yobj.leap_month == (month - 1))
  if yobj.leap_month && yobj.leap_month < month
    month -= 1
  end
  [yobj.year, month, d.jd - month_start +1, is_leap]
end

.find_era(d) ⇒ Object



173
174
175
176
177
178
179
180
181
# File 'lib/wareki/utils.rb', line 173

def find_era(d)
  jd = _to_jd(d)
  ERA_DEFS.reverse_each { |e|
    e.start > jd and next
    e.end < jd and next
    return e
  }
  return nil
end

.find_year(d) ⇒ Object



168
169
170
171
# File 'lib/wareki/utils.rb', line 168

def find_year(d)
  jd = _to_jd(d)
  YEAR_DEFS.bsearch{|y| y.end >= jd }
end

.i_to_kan(num, opts = {}) ⇒ Object



54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
# File 'lib/wareki/utils.rb', line 54

def i_to_kan(num, opts = {})
  ret = ''
  {
    '京' => 10000000000000000,
    '兆' => 1000000000000,
    '億' => 100000000,
    '万' => 10000,
    ''   => 1,
  }.each do |unit4, rank4|
    i4 = (num / rank4).to_i % 10000
    if i4 == 0
      next
    elsif i4 == 1
      ret += "一#{unit4}"
      next
    end
    {
      '千' => 1000,
      '百' => 100,
      '十' => 10,
      ''   => 1,
    }.each do |unit1, rank1|
      i1 = (i4 / rank1).to_i % 10
      if i1 == 0
        next
      elsif i1 == 1 && unit1 != ""
        ret += unit1
      else
        ret += i1.to_s.tr('123456789', '一二三四五六七八九') + unit1
      end
    end
    ret += unit4
  end
  ret
end

.i_to_zen(num) ⇒ Object



90
91
92
# File 'lib/wareki/utils.rb', line 90

def i_to_zen(num)
  num.to_s.tr('0123456789', '0123456789')
end

.kan_to_i(str) ⇒ Object



5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
# File 'lib/wareki/utils.rb', line 5

def kan_to_i(str)
  ret3 = 0
  ret4 = 0
  curnum = nil
  str == "零" and return 0
  str.to_s.each_char do |c|
    case c
    when *%w(正 元 朔 一 二 三 四 五 六 七 八 九 肆 1 2 3 4 5 6 7 8 9 1 2 3 4 5 6 7 8 9)
      if curnum
        curnum *= 10
      else
        curnum = 0
      end
      curnum += c.tr("一二三四五六七八九123456789肆元朔正", "1234567891234567894111").to_i
    when "〇", "0", "0"
      curnum and curnum *= 10
    when "卄", "廿"
      ret3 += 20
      curnum = nil
    when "卅", "丗"
      ret3 += 30
      curnum = nil
    when "卌"
      ret3 += 40
      curnum = nil
    when "皕"
      ret3 += 200
      curnum = nil
    when "万", "億", "兆", "京", "垓"
      if curnum
        ret3 += curnum
        curnum = nil
      end
      ret3 = 1 if ret3 == 0
      ret4 += ret3 * 10 ** ((["万", "億", "兆", "京", "垓"].index(c)+1)*4)
      ret3 = 0
    when "十", "百", "千"
      curnum ||= 1
      ret3 += curnum * 10 ** (["十", "百", "千"].index(c)+1)
      curnum = nil
    end
  end
  if curnum
    ret3 += curnum
    curnum = nil
  end
  ret4 + ret3
end

.last_day_of_month(year, month, is_leap) ⇒ Object



94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
# File 'lib/wareki/utils.rb', line 94

def last_day_of_month(year, month, is_leap)
  if year >= GREGORIAN_START_YEAR
    tmp_y = year
    tmp_m = month
    if month == 12
      tmp_y += 1
      tmp_m = 1
    else
      tmp_m += 1
    end
    day = (::Date.new(tmp_y, tmp_m, 1, ::Date::GREGORIAN)-1).day
  else
    yobj = YEAR_BY_NUM[year] or
      raise UnsupportedDateRange, "Cannot find year #{self.inspect}"
    month_idx = month - 1
    if is_leap || yobj.leap_month && yobj.leap_month < month
      month_idx += 1
    end
    day = yobj.month_days[month_idx]
  end
  day
end