zakuro 0.9.4 → 1.0.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (163) hide show
  1. checksums.yaml +4 -4
  2. data/Gemfile +2 -2
  3. data/README.md +41 -8
  4. data/VERSION +1 -1
  5. data/doc/gengou.md +1 -1
  6. data/doc/operation/csv/month.csv +5 -5
  7. data/doc/operation/operation.xlsx +0 -0
  8. data/images/logo-text.png +0 -0
  9. data/lib/zakuro/calculation/base/gengou.rb +2 -4
  10. data/lib/zakuro/calculation/base/year.rb +1 -1
  11. data/lib/zakuro/calculation/era/gengou/abstract_scroll.rb +2 -2
  12. data/lib/zakuro/calculation/era/gengou/internal/publisher.rb +1 -1
  13. data/lib/zakuro/calculation/era/gengou/internal/reserve/abstract_list.rb +4 -4
  14. data/lib/zakuro/calculation/era/gengou/internal/reserve/empty_link.rb +3 -3
  15. data/lib/zakuro/calculation/era/gengou/internal/reserve/named_list.rb +1 -1
  16. data/lib/zakuro/calculation/era/version/internal/crawler.rb +3 -3
  17. data/lib/zakuro/calculation/monthly/abstract_lunar_phase.rb +1 -1
  18. data/lib/zakuro/calculation/monthly/internal/date_comparer.rb +78 -0
  19. data/lib/zakuro/calculation/monthly/{meta → internal/meta}/all_solar_term.rb +1 -1
  20. data/lib/zakuro/calculation/monthly/{meta → internal/meta}/meta_collector.rb +2 -2
  21. data/lib/zakuro/calculation/monthly/{first_day.rb → internal/part/first_day.rb} +2 -2
  22. data/lib/zakuro/calculation/monthly/{meta.rb → internal/part/meta.rb} +1 -1
  23. data/lib/zakuro/calculation/monthly/internal/solar_term_selector.rb +203 -0
  24. data/lib/zakuro/calculation/monthly/month.rb +30 -125
  25. data/lib/zakuro/calculation/monthly/operated_month.rb +5 -2
  26. data/lib/zakuro/calculation/range/medieval_annual_range.rb +0 -2
  27. data/lib/zakuro/calculation/range/transfer/gengou_scroller.rb +24 -10
  28. data/lib/zakuro/calculation/stella/solar/abstract_average.rb +3 -3
  29. data/lib/zakuro/calculation/summary/internal/option/dropped_date.rb +102 -0
  30. data/lib/zakuro/calculation/summary/internal/option/vanished_date.rb +111 -0
  31. data/lib/zakuro/calculation/summary/internal/option.rb +4 -137
  32. data/lib/zakuro/calculation/summary/japan/range.rb +4 -5
  33. data/lib/zakuro/calculation/summary/western/single.rb +0 -2
  34. data/lib/zakuro/context/version_class_resolver.rb +5 -5
  35. data/lib/zakuro/era/japan/calendar.rb +4 -4
  36. data/lib/zakuro/era/japan/gengou/alignment/division.rb +2 -2
  37. data/lib/zakuro/era/japan/gengou/alignment/linear_gengou.rb +2 -2
  38. data/lib/zakuro/era/japan/gengou/alignment.rb +5 -3
  39. data/lib/zakuro/era/japan/gengou/resource/parser.rb +17 -16
  40. data/lib/zakuro/era/japan/gengou/resource/validator.rb +3 -394
  41. data/lib/zakuro/era/japan/gengou/resource/yaml/set-001-until-south.yaml +2 -2
  42. data/lib/zakuro/era/japan/gengou.rb +3 -3
  43. data/lib/zakuro/era/japan/type/base/both/date.rb +51 -0
  44. data/lib/zakuro/era/japan/type/base/both/year.rb +53 -0
  45. data/lib/zakuro/era/japan/type/base/gengou.rb +177 -0
  46. data/lib/zakuro/era/japan/type/base/gengou_set.rb +78 -0
  47. data/lib/zakuro/era/japan/type/base/switch_date.rb +74 -0
  48. data/lib/zakuro/era/japan/type/base/version_range.rb +189 -0
  49. data/lib/zakuro/era/japan/type/validation/both/date.rb +99 -0
  50. data/lib/zakuro/era/japan/type/validation/both/year.rb +75 -0
  51. data/lib/zakuro/era/japan/type/validation/gengou.rb +93 -0
  52. data/lib/zakuro/era/japan/type/validation/gengou_set.rb +133 -0
  53. data/lib/zakuro/era/japan/type/validation/switch_date.rb +73 -0
  54. data/lib/zakuro/era/japan/type/validation/version_range.rb +109 -0
  55. data/lib/zakuro/era/japan/type/validation/version_root.rb +102 -0
  56. data/lib/zakuro/era/japan/version/resource/parser.rb +266 -0
  57. data/lib/zakuro/era/japan/version/resource/validator.rb +37 -0
  58. data/lib/zakuro/era/japan/version/resource/yaml/version.yaml +80 -0
  59. data/lib/zakuro/era/japan/version/resource.rb +22 -0
  60. data/lib/zakuro/era/japan/version.rb +4 -115
  61. data/lib/zakuro/era/western/calendar.rb +2 -2
  62. data/lib/zakuro/exception/zakuro_error.rb +1 -1
  63. data/lib/zakuro/merchant.rb +5 -5
  64. data/lib/zakuro/operation/month/parser.rb +2 -2
  65. data/lib/zakuro/operation/yaml/month.yaml +5 -5
  66. data/lib/zakuro/output/logger.rb +4 -4
  67. data/lib/zakuro/parameter/catalog/basis_date.rb +55 -0
  68. data/lib/zakuro/parameter/catalog/column.rb +57 -0
  69. data/lib/zakuro/parameter/catalog/option.rb +60 -0
  70. data/lib/zakuro/parameter/catalog/range.rb +81 -0
  71. data/lib/zakuro/parameter/condition.rb +108 -0
  72. data/lib/zakuro/result/core.rb +2 -2
  73. data/lib/zakuro/{tools → tool}/remainder_comparer.rb +2 -4
  74. data/lib/zakuro/{tools → tool}/stringifier.rb +3 -3
  75. data/lib/zakuro/{tools → tool}/typeconv.rb +2 -2
  76. data/lib/zakuro/{tools → tool}/typeof.rb +2 -2
  77. data/lib/zakuro/version/daien/const/number.rb +42 -39
  78. data/lib/zakuro/version/daien/const/remainder.rb +38 -35
  79. data/lib/zakuro/version/daien/cycle/remainder.rb +77 -74
  80. data/lib/zakuro/version/daien/cycle/solar_term.rb +18 -15
  81. data/lib/zakuro/version/daien/daien.rb +8 -5
  82. data/lib/zakuro/version/daien/monthly/lunar_phase.rb +67 -64
  83. data/lib/zakuro/version/daien/option/dropped_date/parameter.rb +15 -12
  84. data/lib/zakuro/version/daien/option/vanished_date/parameter.rb +15 -12
  85. data/lib/zakuro/version/daien/range/annual_range.rb +27 -24
  86. data/lib/zakuro/version/daien/stella/lunar/adjustment.rb +209 -206
  87. data/lib/zakuro/version/daien/stella/lunar/localization.rb +32 -29
  88. data/lib/zakuro/version/daien/stella/lunar/location.rb +53 -50
  89. data/lib/zakuro/version/daien/stella/lunar/value.rb +65 -62
  90. data/lib/zakuro/version/daien/stella/origin/average_november.rb +23 -20
  91. data/lib/zakuro/version/daien/stella/origin/lunar_age.rb +42 -39
  92. data/lib/zakuro/version/daien/stella/origin/winter_solstice.rb +44 -41
  93. data/lib/zakuro/version/daien/stella/solar/adjustment.rb +74 -71
  94. data/lib/zakuro/version/daien/stella/solar/average.rb +68 -65
  95. data/lib/zakuro/version/daien/stella/solar/interval.rb +95 -92
  96. data/lib/zakuro/version/daien/stella/solar/location.rb +41 -38
  97. data/lib/zakuro/version/daien/stella/solar/value.rb +21 -18
  98. data/lib/zakuro/version/genka/const/number.rb +31 -28
  99. data/lib/zakuro/version/genka/const/remainder.rb +20 -17
  100. data/lib/zakuro/version/genka/cycle/remainder.rb +72 -69
  101. data/lib/zakuro/version/genka/cycle/solar_term.rb +18 -15
  102. data/lib/zakuro/version/genka/genka.rb +8 -5
  103. data/lib/zakuro/version/genka/monthly/lunar_phase.rb +82 -79
  104. data/lib/zakuro/version/genka/option/dropped_date/parameter.rb +13 -10
  105. data/lib/zakuro/version/genka/option/vanished_date/parameter.rb +13 -10
  106. data/lib/zakuro/version/genka/range/annual_range.rb +57 -54
  107. data/lib/zakuro/version/genka/stella/origin/first_term.rb +44 -41
  108. data/lib/zakuro/version/genka/stella/origin/january.rb +38 -35
  109. data/lib/zakuro/version/genka/stella/solar/average.rb +24 -21
  110. data/lib/zakuro/version/gihou/const/number.rb +40 -37
  111. data/lib/zakuro/version/gihou/const/remainder.rb +32 -29
  112. data/lib/zakuro/version/gihou/cycle/remainder.rb +38 -35
  113. data/lib/zakuro/version/gihou/cycle/solar_term.rb +18 -15
  114. data/lib/zakuro/version/gihou/gihou.rb +8 -5
  115. data/lib/zakuro/version/gihou/monthly/lunar_phase.rb +68 -65
  116. data/lib/zakuro/version/gihou/option/dropped_date/parameter.rb +13 -10
  117. data/lib/zakuro/version/gihou/option/vanished_date/parameter.rb +13 -10
  118. data/lib/zakuro/version/gihou/range/annual_range.rb +27 -24
  119. data/lib/zakuro/version/gihou/stella/lunar/adjustment.rb +212 -209
  120. data/lib/zakuro/version/gihou/stella/lunar/localization.rb +32 -29
  121. data/lib/zakuro/version/gihou/stella/lunar/location.rb +53 -50
  122. data/lib/zakuro/version/gihou/stella/lunar/value.rb +65 -62
  123. data/lib/zakuro/version/gihou/stella/origin/average_november.rb +23 -20
  124. data/lib/zakuro/version/gihou/stella/origin/lunar_age.rb +42 -39
  125. data/lib/zakuro/version/gihou/stella/origin/winter_solstice.rb +44 -41
  126. data/lib/zakuro/version/gihou/stella/solar/adjustment.rb +74 -71
  127. data/lib/zakuro/version/gihou/stella/solar/average.rb +67 -64
  128. data/lib/zakuro/version/gihou/stella/solar/interval.rb +95 -92
  129. data/lib/zakuro/version/gihou/stella/solar/location.rb +41 -38
  130. data/lib/zakuro/version/gihou/stella/solar/value.rb +21 -18
  131. data/lib/zakuro/version/gregorio/gregorio.rb +8 -5
  132. data/lib/zakuro/version/houryaku/houryaku.rb +8 -5
  133. data/lib/zakuro/version/joukyou/joukyou.rb +8 -5
  134. data/lib/zakuro/version/kansei/kansei.rb +8 -5
  135. data/lib/zakuro/version/senmyou/const/number.rb +40 -37
  136. data/lib/zakuro/version/senmyou/const/remainder.rb +35 -32
  137. data/lib/zakuro/version/senmyou/cycle/remainder.rb +74 -71
  138. data/lib/zakuro/version/senmyou/cycle/solar_term.rb +18 -15
  139. data/lib/zakuro/version/senmyou/monthly/lunar_phase.rb +69 -66
  140. data/lib/zakuro/version/senmyou/option/dropped_date/parameter.rb +15 -12
  141. data/lib/zakuro/version/senmyou/option/vanished_date/parameter.rb +15 -12
  142. data/lib/zakuro/version/senmyou/range/annual_range.rb +27 -24
  143. data/lib/zakuro/version/senmyou/senmyou.rb +8 -5
  144. data/lib/zakuro/version/senmyou/stella/lunar/adjustment.rb +206 -203
  145. data/lib/zakuro/version/senmyou/stella/lunar/localization.rb +32 -29
  146. data/lib/zakuro/version/senmyou/stella/lunar/location.rb +60 -57
  147. data/lib/zakuro/version/senmyou/stella/lunar/value.rb +66 -63
  148. data/lib/zakuro/version/senmyou/stella/origin/average_november.rb +23 -20
  149. data/lib/zakuro/version/senmyou/stella/origin/lunar_age.rb +42 -39
  150. data/lib/zakuro/version/senmyou/stella/origin/winter_solstice.rb +44 -41
  151. data/lib/zakuro/version/senmyou/stella/solar/adjustment.rb +74 -71
  152. data/lib/zakuro/version/senmyou/stella/solar/average.rb +67 -64
  153. data/lib/zakuro/version/senmyou/stella/solar/interval.rb +93 -90
  154. data/lib/zakuro/version/senmyou/stella/solar/location.rb +41 -38
  155. data/lib/zakuro/version/senmyou/stella/solar/value.rb +23 -20
  156. data/lib/zakuro/version/tenpou/tenpou.rb +8 -5
  157. metadata +44 -20
  158. data/lib/zakuro/condition.rb +0 -306
  159. data/lib/zakuro/era/japan/gengou/resource/type.rb +0 -356
  160. data/lib/zakuro/tools/gengou_range_comparer.rb +0 -82
  161. /data/lib/zakuro/calculation/monthly/{operated_solar_term.rb → internal/operated_solar_term.rb} +0 -0
  162. /data/lib/zakuro/calculation/monthly/{const.rb → internal/part/const.rb} +0 -0
  163. /data/lib/zakuro/calculation/monthly/{month_label.rb → internal/part/month_label.rb} +0 -0
@@ -3,10 +3,13 @@
3
3
  require_relative '../cycle/abstract_solar_term'
4
4
 
5
5
  require_relative '../base/gengou'
6
- require_relative './first_day'
7
- require_relative './meta'
8
- require_relative './month_label'
9
- require_relative './meta/meta_collector'
6
+ require_relative './internal/part/first_day'
7
+ require_relative './internal/part/meta'
8
+ require_relative './internal/part/month_label'
9
+ require_relative './internal/meta/meta_collector'
10
+
11
+ require_relative './internal/solar_term_selector'
12
+ require_relative './internal/date_comparer'
10
13
 
11
14
  # :nodoc:
12
15
  module Zakuro
@@ -24,8 +27,8 @@ module Zakuro
24
27
  attr_reader :month_label
25
28
  # @return [FirstDay] 月初日(朔日)
26
29
  attr_reader :first_day
27
- # @return [Array<Cyle::AbstractSolarTerm>] 二十四節気
28
- attr_reader :solar_terms
30
+ # @return [SolarTermSelector] 二十四節気検索
31
+ attr_reader :solar_term_selector
29
32
  # @return [Base::Gengou] 元号
30
33
  attr_reader :gengou
31
34
  # @return [Meta] 付加情報
@@ -49,7 +52,7 @@ module Zakuro
49
52
  @context = context
50
53
  @month_label = month_label
51
54
  @first_day = first_day
52
- @solar_terms = solar_terms
55
+ @solar_term_selector = SolarTermSelector.new(context: context, solar_terms: solar_terms)
53
56
  @gengou = gengou
54
57
  @meta = meta
55
58
  end
@@ -160,7 +163,7 @@ module Zakuro
160
163
  # @return [False] 設定あり
161
164
  #
162
165
  def empty_solar_term?
163
- solar_terms.empty?
166
+ solar_term_selector.empty?
164
167
  end
165
168
 
166
169
  #
@@ -169,11 +172,7 @@ module Zakuro
169
172
  # @return [Cycle::AbstractSolarTerm] 中気
170
173
  #
171
174
  def even_term
172
- solar_terms.each do |term|
173
- return term if term.index.even?
174
- end
175
-
176
- context.resolver.solar_term.new
175
+ solar_term_selector.even_term
177
176
  end
178
177
 
179
178
  #
@@ -182,11 +181,16 @@ module Zakuro
182
181
  # @return [Cycle::AbstractSolarTerm] 節気
183
182
  #
184
183
  def odd_term
185
- solar_terms.each do |term|
186
- return term if term.index.odd?
187
- end
184
+ solar_term_selector.odd_term
185
+ end
188
186
 
189
- context.resolver.solar_term.new
187
+ #
188
+ # 二十四節気を返す
189
+ #
190
+ # @return [Array<Cyle::AbstractSolarTerm>] 二十四節気
191
+ #
192
+ def solar_terms
193
+ solar_term_selector.solar_terms
190
194
  end
191
195
 
192
196
  #
@@ -195,7 +199,7 @@ module Zakuro
195
199
  # @param [SolarTerm] term 二十四節気
196
200
  #
197
201
  def add_term(term:)
198
- solar_terms.push(term)
202
+ solar_term_selector.add_term(term: term)
199
203
  end
200
204
 
201
205
  #
@@ -232,14 +236,9 @@ module Zakuro
232
236
  def include?(date:)
233
237
  return false if invalid?
234
238
 
235
- start_date = western_date
236
- return false if start_date.invalid?
237
-
238
- return false if date < start_date
239
-
240
- return false if date > last_date
241
-
242
- true
239
+ DateComparer.include?(
240
+ date: date, start_date: western_date, last_date: last_date
241
+ )
243
242
  end
244
243
 
245
244
  #
@@ -253,46 +252,16 @@ module Zakuro
253
252
  def include_by_japan_date?(date:)
254
253
  return false if invalid?
255
254
 
256
- linear_gengou = gengou.match_by_name(name: date.gengou)
257
- return false if linear_gengou.invalid?
258
-
259
- return false unless linear_gengou.name == date.gengou
260
-
261
- return false unless linear_gengou.year == date.year
262
-
263
- same_by_japan_date?(date: date)
255
+ DateComparer.include_by_japan_date?(
256
+ date: date, gengou: gengou, month_label: month_label
257
+ )
264
258
  end
265
259
 
266
260
  #
267
261
  # 二十四節気を正しい順序にソートする
268
262
  #
269
263
  def sort_solar_terms
270
- # TODO: refactor
271
- sorted = (solar_terms.sort do |termx, termy|
272
- termx.index <=> termy.index
273
- end)
274
-
275
- unless reset_term?(solar_terms: sorted)
276
- @solar_terms = sorted
277
- return
278
- end
279
-
280
- first = []
281
- second = []
282
-
283
- sorted.each do |term|
284
- if term.index >= (23 - 2)
285
- second.push(term)
286
- next
287
- end
288
-
289
- first.push(term)
290
- end
291
-
292
- # 0以前を先頭にする
293
- second += first
294
-
295
- @solar_terms = second
264
+ solar_term_selector.sort
296
265
  end
297
266
 
298
267
  #
@@ -303,28 +272,7 @@ module Zakuro
303
272
  # @return [Cycle::AbstractSolarTerm] 二十四節気
304
273
  #
305
274
  def solar_term_by_day(day:)
306
- # TODO: refactor
307
- target = context.resolver.remainder.new(day: day, minute: 0, second: 0)
308
-
309
- meta.all_solar_terms.each_cons(2) do |current_solar_term, next_solar_term|
310
- in_range = Tools::RemainderComparer.in_range?(
311
- target: target, start: current_solar_term.remainder, last: next_solar_term.remainder
312
- )
313
- return current_solar_term if in_range
314
- end
315
-
316
- last_solar_term = meta.all_solar_terms[-1]
317
-
318
- empty_solar_term = context.resolver.solar_term.new
319
-
320
- return empty_solar_term unless last_solar_term
321
- # NOTE: 大余20を上限として範囲チェックする
322
- if Tools::RemainderComparer.in_limit?(target: target, start: last_solar_term.remainder,
323
- limit: 20)
324
- return last_solar_term
325
- end
326
-
327
- empty_solar_term
275
+ solar_term_selector.solar_term_by_day(day: day, meta: meta)
328
276
  end
329
277
 
330
278
  #
@@ -338,49 +286,6 @@ module Zakuro
338
286
  current_month: self
339
287
  )
340
288
  end
341
-
342
- private
343
-
344
- #
345
- # 同一の月情報かを検証する
346
- #
347
- # @param [Japan::Calendar] date 日付
348
- #
349
- # @return [True] 同一の月
350
- # @return [False] 異なる月
351
- #
352
- def same_by_japan_date?(date: Japan::Calendar.new)
353
- return false unless number == date.month
354
-
355
- return false unless leaped? == date.leaped
356
-
357
- true
358
- end
359
-
360
- #
361
- # 二十四節気の折り返し(23 -> 0)があるか
362
- #
363
- # @param [Array<Cyle::AbstractSolarTerm>] solar_terms 二十四節気
364
- #
365
- # @return [True] 折り返しあり
366
- # @return [False] 折り返しなし
367
- #
368
- def reset_term?(solar_terms: [])
369
- first = false
370
- last = false
371
-
372
- solar_terms.each do |term|
373
- index = term.index
374
- case index
375
- when Cycle::AbstractSolarTerm::FIRST_INDEX
376
- first = true
377
- when Cycle::AbstractSolarTerm::LAST_INDEX
378
- last = true
379
- end
380
- end
381
-
382
- first && last
383
- end
384
289
  end
385
290
  end
386
291
  end
@@ -1,7 +1,7 @@
1
1
  # frozen_string_literal: true
2
2
 
3
3
  require_relative '../../operation/operation'
4
- require_relative './operated_solar_term'
4
+ require_relative './internal/operated_solar_term'
5
5
  require_relative './month'
6
6
 
7
7
  # :nodoc:
@@ -87,10 +87,13 @@ module Zakuro
87
87
 
88
88
  return unless matched
89
89
 
90
- @solar_terms = OperatedSolarTerm.create_operated_solar_term(
90
+ operated_solar_terms = OperatedSolarTerm.create_operated_solar_term(
91
91
  operated_solar_term: solar_term,
92
92
  solar_terms: solar_terms
93
93
  )
94
+ @solar_term_selector = SolarTermSelector.new(
95
+ context: context, solar_terms: operated_solar_terms
96
+ )
94
97
  end
95
98
 
96
99
  #
@@ -2,8 +2,6 @@
2
2
 
3
3
  require_relative '../../output/logger'
4
4
  require_relative '../monthly/initialized_month'
5
- require_relative '../monthly/month_label'
6
- require_relative '../monthly/first_day'
7
5
 
8
6
  # :nodoc:
9
7
  module Zakuro
@@ -38,19 +38,33 @@ module Zakuro
38
38
  year.months.each_with_index do |month, index|
39
39
  scroll.run(month: month)
40
40
  gengou = scroll.to_gengou
41
- year.months[index] = Monthly::Month.new(
42
- context: month.context,
43
- month_label: month.month_label,
44
- first_day: Monthly::FirstDay.new(
45
- remainder: month.first_day.remainder,
46
- average_remainder: month.first_day.average_remainder,
47
- western_date: gengou.start_date.clone
48
- ),
49
- solar_terms: month.solar_terms, gengou: gengou,
50
- meta: month.meta
41
+ year.months[index] = replace_gengou(
42
+ month: month, gengou: gengou
51
43
  )
52
44
  end
53
45
  end
46
+
47
+ #
48
+ # 月情報のうち元号を差し替える
49
+ #
50
+ # @param [Monthly::Month] month 月情報
51
+ # @param [Base::Gengou] gengou 元号
52
+ #
53
+ # @return [Monthly::Month] 月情報
54
+ #
55
+ def replace_gengou(month:, gengou:)
56
+ Monthly::Month.new(
57
+ context: month.context,
58
+ month_label: month.month_label,
59
+ first_day: Monthly::FirstDay.new(
60
+ remainder: month.first_day.remainder,
61
+ average_remainder: month.first_day.average_remainder,
62
+ western_date: gengou.start_date.clone
63
+ ),
64
+ solar_terms: month.solar_terms, gengou: gengou,
65
+ meta: month.meta
66
+ )
67
+ end
54
68
  end
55
69
  end
56
70
  end
@@ -1,8 +1,8 @@
1
1
  # frozen_string_literal: true
2
2
 
3
- require_relative '../../monthly/meta/meta_collector'
3
+ require_relative '../../monthly/internal/meta/meta_collector'
4
4
 
5
- require_relative '../../../tools/remainder_comparer'
5
+ require_relative '../../../tool/remainder_comparer'
6
6
 
7
7
  # :nodoc:
8
8
  module Zakuro
@@ -62,7 +62,7 @@ module Zakuro
62
62
  # * 閏月は1回しか設定しない
63
63
  # * 最大2回設定する(中気・節気)
64
64
  4.times.each do |_index|
65
- in_range = Tools::RemainderComparer.in_range?(
65
+ in_range = Tool::RemainderComparer.in_range?(
66
66
  target: solar_term.remainder, start: current_month.remainder,
67
67
  last: next_month.remainder
68
68
  )
@@ -0,0 +1,102 @@
1
+ # frozen_string_literal: true
2
+
3
+ require_relative '../../../../context/option'
4
+ require_relative '../../../../result/data/option/dropped_date/option'
5
+ require_relative '../../../../result/data/solar_term'
6
+
7
+ require_relative '../../../option/dropped_date/location'
8
+
9
+ # :nodoc:
10
+ module Zakuro
11
+ # :nodoc:
12
+ module Calculation
13
+ # :nodoc:
14
+ module Summary
15
+ #
16
+ # Option オプション
17
+ #
18
+ module Option
19
+ #
20
+ # DroppedDate 没日
21
+ #
22
+ module DroppedDate
23
+ class << self
24
+ #
25
+ # 没日を取得する
26
+ #
27
+ # @param [Calculation::Monthly::Month] month 月情報(各暦のデータ型)
28
+ # @param [Calculation::Base::Day] day 日情報
29
+ #
30
+ # @return [Result::Data::Option::DroppedDate::Option] 没日
31
+ #
32
+ def get(month:, day:)
33
+ context = month.context
34
+
35
+ solar_term = month.solar_term_by_day(day: day.remainder.day)
36
+
37
+ remainder = day.remainder
38
+
39
+ dropped_date(
40
+ context: context, remainder: remainder, solar_term: solar_term
41
+ )
42
+ end
43
+
44
+ private
45
+
46
+ #
47
+ # 没日を求める
48
+ #
49
+ # @param [Context::Context] context 暦コンテキスト
50
+ # @param [Cycle::AbstractRemainder] remainder 当日和暦日
51
+ # @param [Cycle::AbstractSolarTerm] solar_terms 二十四節気
52
+ #
53
+ # @return [Result::Data::Option::DroppedDate::Option] 没日
54
+ #
55
+ def dropped_date(context:, remainder:, solar_term:)
56
+ option = Result::Data::Option::DroppedDate::Option.new
57
+
58
+ return option if remainder.invalid?
59
+
60
+ location = Calculation::Option::DroppedDate::Location.new(
61
+ context: context, solar_term: solar_term
62
+ )
63
+
64
+ return option if location.invalid?
65
+
66
+ return option unless location.exist?
67
+
68
+ dropped_date = location.get
69
+
70
+ dropped_date_option(
71
+ matched: remainder.day == dropped_date.day, location: location
72
+ )
73
+ end
74
+
75
+ #
76
+ # 没日オプション値を生成する
77
+ #
78
+ # @param [True, False] matched 没日有無
79
+ # @param [Calculation::Option::DroppedDate::Location] location 没日位置
80
+ #
81
+ # @return [Result::Data::Option::DroppedDate::Option] 没日オプション値
82
+ #
83
+ def dropped_date_option(matched:, location:)
84
+ dropped_date = location.get
85
+ solar_term = location.solar_term
86
+ Result::Data::Option::DroppedDate::Option.new(
87
+ matched: matched,
88
+ calculation: Result::Data::Option::DroppedDate::Calculation.new(
89
+ remainder: dropped_date.format,
90
+ solar_term: Result::Data::SolarTerm.new(
91
+ index: solar_term.index,
92
+ remainder: solar_term.remainder.format
93
+ )
94
+ )
95
+ )
96
+ end
97
+ end
98
+ end
99
+ end
100
+ end
101
+ end
102
+ end
@@ -0,0 +1,111 @@
1
+ # frozen_string_literal: true
2
+
3
+ require_relative '../../../../context/option'
4
+ require_relative '../../../../result/data/option/vanished_date/option'
5
+ require_relative '../../../../result/data/solar_term'
6
+
7
+ require_relative '../../../option/vanished_date/location'
8
+
9
+ # :nodoc:
10
+ module Zakuro
11
+ # :nodoc:
12
+ module Calculation
13
+ # :nodoc:
14
+ module Summary
15
+ #
16
+ # Option オプション
17
+ #
18
+ module Option
19
+ #
20
+ # VanishedDate 滅日
21
+ #
22
+ module VanishedDate
23
+ class << self
24
+ #
25
+ # 滅日を取得する
26
+ #
27
+ # @param [Calculation::Monthly::Month] month 月情報(各暦のデータ型)
28
+ # @param [Calculation::Base::Day] day 日情報
29
+ #
30
+ # @return [Result::Data::Option::VanishedDate::Option] 滅日オプション値
31
+ #
32
+ def get(month:, day:)
33
+ context = month.context
34
+
35
+ remainder = day.remainder
36
+ average_remainder = month.first_day.average_remainder
37
+ # p "remainder: #{remainder.format}"
38
+ # p "last_average_remainder: #{month.meta.last_average_remainder.format}"
39
+
40
+ if day.number == 1
41
+ option = vanished_date(
42
+ context: context, remainder: remainder,
43
+ average_remainder: month.meta.last_average_remainder
44
+ )
45
+
46
+ return option if option.matched
47
+ end
48
+
49
+ vanished_date(
50
+ context: context, remainder: remainder, average_remainder: average_remainder
51
+ )
52
+ end
53
+
54
+ private
55
+
56
+ #
57
+ # 滅日を求める
58
+ #
59
+ # @param [Context::Context] context 暦コンテキスト
60
+ # @param [Cycle::AbstractRemainder] remainder 当日和暦日
61
+ # @param [Cycle::AbstractRemainder] average_remainder 経朔
62
+ #
63
+ # @return [Result::Data::Option::VanishedDate::Option] 滅日オプション値
64
+ #
65
+ def vanished_date(context:, remainder:, average_remainder:)
66
+ return Result::Data::Option::VanishedDate::Option.new if average_remainder.invalid?
67
+
68
+ location = Calculation::Option::VanishedDate::Location.new(
69
+ context: context, average_remainder: average_remainder
70
+ )
71
+
72
+ return Result::Data::Option::VanishedDate::Option.new if location.invalid?
73
+
74
+ unless location.exist?
75
+ # 結果確認のため経朔だけは設定する
76
+ return Result::Data::Option::VanishedDate::Option.new(
77
+ calculation: Result::Data::Option::VanishedDate::Calculation.new(
78
+ average_remainder: average_remainder
79
+ )
80
+ )
81
+ end
82
+
83
+ vanished_date = location.get
84
+
85
+ vanished_date_option(matched: remainder.day == vanished_date.day, location: location)
86
+ end
87
+
88
+ #
89
+ # 滅日オプション値を生成する
90
+ #
91
+ # @param [True, False] matched 滅日有無
92
+ # @param [Calculation::Option::VanishedDate::Location] location 滅日位置
93
+ #
94
+ # @return [Result::Data::Option::VanishedDate::Option] 滅日オプション値
95
+ #
96
+ def vanished_date_option(matched:, location:)
97
+ vanished_date = location.get
98
+ Result::Data::Option::VanishedDate::Option.new(
99
+ matched: matched,
100
+ calculation: Result::Data::Option::VanishedDate::Calculation.new(
101
+ remainder: vanished_date.format,
102
+ average_remainder: location.average_remainder
103
+ )
104
+ )
105
+ end
106
+ end
107
+ end
108
+ end
109
+ end
110
+ end
111
+ end