zakuro 0.6.1 → 0.8.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (181) hide show
  1. checksums.yaml +4 -4
  2. data/Makefile +3 -0
  3. data/README.md +46 -17
  4. data/VERSION +1 -1
  5. data/doc/dropped_date.md +93 -0
  6. data/doc/error.md +45 -0
  7. data/doc/operation/transfer.rb +8 -8
  8. data/lib/zakuro/calculation/base/day.rb +52 -0
  9. data/lib/zakuro/calculation/base/gengou.rb +49 -3
  10. data/lib/zakuro/calculation/base/linear_gengou.rb +5 -5
  11. data/lib/zakuro/calculation/base/operated_year.rb +26 -24
  12. data/lib/zakuro/calculation/base/year.rb +7 -7
  13. data/lib/zakuro/calculation/cycle/abstract_remainder.rb +55 -47
  14. data/lib/zakuro/calculation/cycle/abstract_solar_term.rb +28 -24
  15. data/lib/zakuro/calculation/cycle/zodiac.rb +22 -20
  16. data/lib/zakuro/calculation/era/gengou/{scroll.rb → abstract_scroll.rb} +44 -37
  17. data/lib/zakuro/calculation/era/gengou/dated_scroll.rb +30 -0
  18. data/lib/zakuro/calculation/era/gengou/internal/connector.rb +4 -4
  19. data/lib/zakuro/calculation/era/gengou/internal/counter.rb +16 -16
  20. data/lib/zakuro/calculation/era/gengou/internal/publisher.rb +74 -72
  21. data/lib/zakuro/calculation/era/gengou/internal/reserve/{list.rb → abstract_list.rb} +50 -64
  22. data/lib/zakuro/calculation/era/gengou/internal/reserve/{range.rb → abstract_range.rb} +73 -50
  23. data/lib/zakuro/calculation/era/gengou/internal/reserve/dated_list.rb +48 -0
  24. data/lib/zakuro/calculation/era/gengou/internal/reserve/dated_range.rb +30 -0
  25. data/lib/zakuro/calculation/era/gengou/internal/reserve/empty_link.rb +156 -0
  26. data/lib/zakuro/calculation/era/gengou/internal/reserve/named_list.rb +125 -0
  27. data/lib/zakuro/calculation/era/gengou/internal/reserve/named_range.rb +73 -0
  28. data/lib/zakuro/calculation/era/gengou/internal/reserve.rb +23 -22
  29. data/lib/zakuro/calculation/era/gengou/named_scroll.rb +30 -0
  30. data/lib/zakuro/calculation/era/version/internal/crawler.rb +39 -22
  31. data/lib/zakuro/calculation/era/version/version.rb +12 -10
  32. data/lib/zakuro/calculation/monthly/abstract_lunar_phase.rb +13 -9
  33. data/lib/zakuro/calculation/monthly/const.rb +18 -0
  34. data/lib/zakuro/calculation/monthly/initialized_month.rb +40 -38
  35. data/lib/zakuro/calculation/monthly/month.rb +55 -16
  36. data/lib/zakuro/calculation/monthly/month_label.rb +4 -4
  37. data/lib/zakuro/calculation/monthly/operated_month.rb +37 -86
  38. data/lib/zakuro/calculation/monthly/operated_solar_term.rb +80 -0
  39. data/lib/zakuro/calculation/option/dropped_date/abstract_parameter.rb +44 -0
  40. data/lib/zakuro/calculation/option/dropped_date/location.rb +135 -0
  41. data/lib/zakuro/calculation/range/{full_range.rb → abstract_full_range.rb} +45 -29
  42. data/lib/zakuro/calculation/range/abstract_operation_range.rb +193 -0
  43. data/lib/zakuro/calculation/range/dated_full_range.rb +32 -0
  44. data/lib/zakuro/calculation/range/dated_operation_range.rb +33 -0
  45. data/lib/zakuro/calculation/range/medieval_annual_range.rb +64 -63
  46. data/lib/zakuro/calculation/range/named_full_range.rb +38 -0
  47. data/lib/zakuro/calculation/range/named_operation_range.rb +36 -0
  48. data/lib/zakuro/calculation/range/operated_solar_term.rb +220 -0
  49. data/lib/zakuro/calculation/range/transfer/gengou_scroller.rb +32 -29
  50. data/lib/zakuro/calculation/range/transfer/year_boundary.rb +115 -117
  51. data/lib/zakuro/calculation/stella/lunar/abstract_location.rb +1 -1
  52. data/lib/zakuro/calculation/stella/lunar/choukei_value.rb +48 -46
  53. data/lib/zakuro/calculation/stella/solar/abstract_average.rb +31 -26
  54. data/lib/zakuro/calculation/stella/solar/abstract_location.rb +7 -5
  55. data/lib/zakuro/calculation/stella/solar/choukei_value.rb +114 -114
  56. data/lib/zakuro/calculation/summary/internal/day.rb +42 -0
  57. data/lib/zakuro/calculation/{specifier → summary}/internal/month.rb +33 -12
  58. data/lib/zakuro/calculation/summary/internal/operation.rb +68 -67
  59. data/lib/zakuro/calculation/summary/internal/option.rb +101 -0
  60. data/lib/zakuro/calculation/summary/japan/range.rb +179 -0
  61. data/lib/zakuro/calculation/summary/japan/single.rb +118 -0
  62. data/lib/zakuro/calculation/summary/japan/specifier/single_day.rb +98 -0
  63. data/lib/zakuro/calculation/summary/japan/specifier/specified_range.rb +34 -0
  64. data/lib/zakuro/calculation/summary/western/range.rb +127 -0
  65. data/lib/zakuro/calculation/summary/western/single.rb +115 -0
  66. data/lib/zakuro/calculation/summary/western/specifier/multiple_day.rb +173 -0
  67. data/lib/zakuro/calculation/summary/western/specifier/single_day.rb +100 -0
  68. data/lib/zakuro/calculation/type/old_float.rb +2 -2
  69. data/lib/zakuro/calculation/type/optional.rb +46 -0
  70. data/lib/zakuro/condition.rb +143 -94
  71. data/lib/zakuro/context/context.rb +44 -0
  72. data/lib/zakuro/context/option.rb +119 -0
  73. data/lib/zakuro/context/version_class_resolver.rb +112 -0
  74. data/lib/zakuro/era/japan/calendar.rb +35 -33
  75. data/lib/zakuro/era/japan/gengou/alignment/aligner.rb +93 -74
  76. data/lib/zakuro/era/japan/gengou/alignment/division.rb +135 -133
  77. data/lib/zakuro/era/japan/gengou/alignment/line.rb +143 -122
  78. data/lib/zakuro/era/japan/gengou/alignment/linear_gengou.rb +177 -168
  79. data/lib/zakuro/era/japan/gengou/alignment.rb +40 -25
  80. data/lib/zakuro/era/japan/gengou/resource/parser.rb +199 -181
  81. data/lib/zakuro/era/japan/gengou/resource/type.rb +243 -234
  82. data/lib/zakuro/era/japan/gengou/resource/validator.rb +257 -254
  83. data/lib/zakuro/era/japan/gengou/resource.rb +23 -22
  84. data/lib/zakuro/era/japan/gengou.rb +28 -41
  85. data/lib/zakuro/era/japan/version.rb +18 -16
  86. data/lib/zakuro/era/western/calendar.rb +104 -88
  87. data/lib/zakuro/exception/case/pattern.rb +71 -0
  88. data/lib/zakuro/exception/case/preset.rb +51 -0
  89. data/lib/zakuro/exception/case/template.rb +48 -0
  90. data/lib/zakuro/exception/cause.rb +28 -0
  91. data/lib/zakuro/exception/exception.rb +39 -0
  92. data/lib/zakuro/exception/zakuro_error.rb +46 -0
  93. data/lib/zakuro/gateway/locale/date.rb +127 -0
  94. data/lib/zakuro/gateway/locale/range.rb +67 -0
  95. data/lib/zakuro/gateway/range.rb +99 -0
  96. data/lib/zakuro/gateway/single.rb +81 -0
  97. data/lib/zakuro/merchant.rb +67 -33
  98. data/lib/zakuro/operation/month/parser.rb +252 -249
  99. data/lib/zakuro/operation/month/type.rb +44 -35
  100. data/lib/zakuro/operation/month/validator.rb +182 -178
  101. data/lib/zakuro/operation/operation.rb +38 -36
  102. data/lib/zakuro/operation/yaml/month.yaml +3736 -3736
  103. data/lib/zakuro/output/logger.rb +17 -3
  104. data/lib/zakuro/output/response.rb +107 -141
  105. data/lib/zakuro/result/data/day.rb +43 -0
  106. data/lib/zakuro/result/data/gengou.rb +35 -0
  107. data/lib/zakuro/result/data/month.rb +63 -0
  108. data/lib/zakuro/result/data/option/abstract_option.rb +37 -0
  109. data/lib/zakuro/result/data/option/dropped_date/calculation.rb +47 -0
  110. data/lib/zakuro/result/data/option/dropped_date/option.rb +47 -0
  111. data/lib/zakuro/result/data/option/dropped_date/solar_term.rb +48 -0
  112. data/lib/zakuro/result/data/single_day.rb +56 -0
  113. data/lib/zakuro/result/data/solar_term.rb +35 -0
  114. data/lib/zakuro/result/data/year.rb +45 -0
  115. data/lib/zakuro/result/operation/month/annotation.rb +40 -0
  116. data/lib/zakuro/result/operation/month/history.rb +54 -0
  117. data/lib/zakuro/result/operation/month.rb +31 -0
  118. data/lib/zakuro/result/operation.rb +22 -97
  119. data/lib/zakuro/result/result.rb +6 -4
  120. data/lib/zakuro/tools/stringifier.rb +67 -42
  121. data/lib/zakuro/tools/typeconv.rb +17 -15
  122. data/lib/zakuro/tools/typeof.rb +15 -13
  123. data/lib/zakuro/version/daien/cycle/remainder.rb +2 -2
  124. data/lib/zakuro/version/daien/monthly/lunar_phase.rb +10 -12
  125. data/lib/zakuro/version/daien/option/dropped_date/parameter.rb +31 -0
  126. data/lib/zakuro/version/daien/range/annual_range.rb +19 -17
  127. data/lib/zakuro/version/daien/stella/lunar/adjustment.rb +42 -37
  128. data/lib/zakuro/version/daien/stella/lunar/localization.rb +16 -14
  129. data/lib/zakuro/version/daien/stella/lunar/value.rb +52 -47
  130. data/lib/zakuro/version/daien/stella/origin/average_november.rb +15 -13
  131. data/lib/zakuro/version/daien/stella/origin/lunar_age.rb +23 -21
  132. data/lib/zakuro/version/daien/stella/origin/winter_solstice.rb +22 -20
  133. data/lib/zakuro/version/daien/stella/solar/adjustment.rb +12 -10
  134. data/lib/zakuro/version/daien/stella/solar/average.rb +53 -51
  135. data/lib/zakuro/version/daien/stella/solar/interval.rb +19 -17
  136. data/lib/zakuro/version/daien/stella/solar/value.rb +13 -11
  137. data/lib/zakuro/version/genka/cycle/remainder.rb +4 -4
  138. data/lib/zakuro/version/genka/monthly/lunar_phase.rb +7 -5
  139. data/lib/zakuro/version/genka/option/dropped_date/parameter.rb +31 -0
  140. data/lib/zakuro/version/genka/range/annual_range.rb +48 -44
  141. data/lib/zakuro/version/genka/stella/origin/first_term.rb +30 -28
  142. data/lib/zakuro/version/genka/stella/origin/january.rb +22 -20
  143. data/lib/zakuro/version/gihou/cycle/remainder.rb +2 -2
  144. data/lib/zakuro/version/gihou/monthly/lunar_phase.rb +9 -9
  145. data/lib/zakuro/version/gihou/option/dropped_date/parameter.rb +31 -0
  146. data/lib/zakuro/version/gihou/range/annual_range.rb +19 -17
  147. data/lib/zakuro/version/gihou/stella/lunar/adjustment.rb +42 -37
  148. data/lib/zakuro/version/gihou/stella/lunar/localization.rb +16 -14
  149. data/lib/zakuro/version/gihou/stella/lunar/value.rb +52 -47
  150. data/lib/zakuro/version/gihou/stella/origin/average_november.rb +15 -13
  151. data/lib/zakuro/version/gihou/stella/origin/lunar_age.rb +23 -21
  152. data/lib/zakuro/version/gihou/stella/origin/winter_solstice.rb +24 -22
  153. data/lib/zakuro/version/gihou/stella/solar/adjustment.rb +12 -10
  154. data/lib/zakuro/version/gihou/stella/solar/average.rb +52 -50
  155. data/lib/zakuro/version/gihou/stella/solar/interval.rb +19 -17
  156. data/lib/zakuro/version/gihou/stella/solar/value.rb +13 -11
  157. data/lib/zakuro/version/senmyou/const/remainder.rb +5 -0
  158. data/lib/zakuro/version/senmyou/cycle/remainder.rb +37 -2
  159. data/lib/zakuro/version/senmyou/monthly/lunar_phase.rb +10 -10
  160. data/lib/zakuro/version/senmyou/option/dropped_date/parameter.rb +33 -0
  161. data/lib/zakuro/version/senmyou/range/annual_range.rb +19 -17
  162. data/lib/zakuro/version/senmyou/stella/lunar/adjustment.rb +42 -36
  163. data/lib/zakuro/version/senmyou/stella/lunar/localization.rb +16 -14
  164. data/lib/zakuro/version/senmyou/stella/lunar/value.rb +39 -34
  165. data/lib/zakuro/version/senmyou/stella/origin/average_november.rb +15 -13
  166. data/lib/zakuro/version/senmyou/stella/origin/lunar_age.rb +23 -21
  167. data/lib/zakuro/version/senmyou/stella/origin/winter_solstice.rb +22 -20
  168. data/lib/zakuro/version/senmyou/stella/solar/adjustment.rb +12 -10
  169. data/lib/zakuro/version/senmyou/stella/solar/average.rb +52 -50
  170. data/lib/zakuro/version/senmyou/stella/solar/interval.rb +19 -17
  171. data/lib/zakuro/version/senmyou/stella/solar/value.rb +13 -11
  172. metadata +68 -16
  173. data/lib/zakuro/calculation/range/operated_range.rb +0 -193
  174. data/lib/zakuro/calculation/range/operated_solar_terms.rb +0 -220
  175. data/lib/zakuro/calculation/specifier/multiple_day.rb +0 -162
  176. data/lib/zakuro/calculation/specifier/single_day.rb +0 -87
  177. data/lib/zakuro/calculation/summary/range.rb +0 -120
  178. data/lib/zakuro/calculation/summary/single.rb +0 -110
  179. data/lib/zakuro/result/data.rb +0 -187
  180. data/lib/zakuro/version/context.rb +0 -44
  181. data/lib/zakuro/version/version_class_resolver.rb +0 -74
@@ -0,0 +1,115 @@
1
+ # frozen_string_literal: true
2
+
3
+ require_relative '../../range/dated_operation_range'
4
+
5
+ require_relative '../../range/dated_full_range'
6
+
7
+ require_relative './specifier/single_day'
8
+
9
+ require_relative '../internal/operation'
10
+
11
+ # :nodoc:
12
+ module Zakuro
13
+ # :nodoc:
14
+ module Calculation
15
+ # :nodoc:
16
+ module Summary
17
+ # :nodoc:
18
+ module Western
19
+ #
20
+ # Single 一日
21
+ #
22
+ module Single
23
+ class << self
24
+ #
25
+ # 生成する
26
+ #
27
+ # @param [Context::Context] context 暦コンテキスト
28
+ # @param [Western::Calendar] date 西暦日
29
+ #
30
+ # @return [Result::Single] 一日検索結果(和暦日)
31
+ #
32
+ def get(context:, date: Western::Calendar.new)
33
+ years = get_full_range_years(context: context, date: date)
34
+
35
+ data = get_data(context: context, years: years, date: date)
36
+
37
+ operation = get_operation(years: years, date: date)
38
+
39
+ Result::Single.new(
40
+ data: data,
41
+ operation: operation
42
+ )
43
+ end
44
+
45
+ private
46
+
47
+ #
48
+ # 完全範囲を取得する
49
+ #
50
+ # @param [Context::Context] context 暦コンテキスト
51
+ # @param [Western::Calendar] date 西暦日
52
+ #
53
+ # @return [Array<Calculation::Base::Year>] 完全範囲
54
+ #
55
+ def get_full_range_years(context:, date: Western::Calendar.new)
56
+ full_range = Calculation::Range::DatedFullRange.new(
57
+ context: context, start_date: date
58
+ )
59
+ full_range.get
60
+ end
61
+
62
+ #
63
+ # 運用結果範囲を取得する
64
+ #
65
+ # @param [Context::Context] context 暦コンテキスト
66
+ # @param [Array<Calculation::Base::Year>] years 完全範囲
67
+ # @param [Western::Calendar] date 西暦日
68
+ #
69
+ # @return [Array<Base::OperatedYear>] 運用結果範囲
70
+ #
71
+ def get_operation_range_years(context:, years:, date: Western::Calendar.new)
72
+ operation_range = Calculation::Range::DatedOperationRange.new(
73
+ context: context, start_date: date, years: years
74
+ )
75
+ operation_range.get
76
+ end
77
+
78
+ #
79
+ # 1日を取得する
80
+ #
81
+ # @param [Context::Context] context 暦コンテキスト
82
+ # @param [Array<Calculation::Base::Year>] years 完全範囲
83
+ # @param [Western::Calendar] date 西暦日
84
+ #
85
+ # @return [Data::SingleDay] 1日
86
+ #
87
+ def get_data(context:, years:, date: Western::Calendar.new)
88
+ operated_years = get_operation_range_years(context: context, years: years, date: date)
89
+
90
+ Specifier::SingleDay.get(
91
+ years: operated_years, date: date
92
+ )
93
+ end
94
+
95
+ #
96
+ # 完全範囲を取得する
97
+ #
98
+ # @param [Array<Calculation::Base::Year>] years 完全範囲
99
+ # @param [Western::Calendar] date 西暦日
100
+ #
101
+ # @return [Array<Calculation::Base::Year>] 完全範囲
102
+ #
103
+ def get_operation(years:, date: Western::Calendar.new)
104
+ calc_date = Specifier::SingleDay.get(
105
+ years: years, date: date
106
+ )
107
+
108
+ Operation.create(calc_date: calc_date)
109
+ end
110
+ end
111
+ end
112
+ end
113
+ end
114
+ end
115
+ end
@@ -0,0 +1,173 @@
1
+ # frozen_string_literal: true
2
+
3
+ require_relative '../../../../era/western/calendar'
4
+ require_relative '../../../../output/response'
5
+ require_relative '../../../../output/logger'
6
+
7
+ require_relative '../../../base/year'
8
+
9
+ require_relative '../../internal/month'
10
+
11
+ # :nodoc:
12
+ module Zakuro
13
+ # :nodoc:
14
+ module Calculation
15
+ # :nodoc:
16
+ module Summary
17
+ # :nodoc:
18
+ module Western
19
+ # :nodoc:
20
+ module Specifier
21
+ #
22
+ # MultipleDay 複数日検索
23
+ #
24
+ module MultipleDay
25
+ # @return [Output::Logger] ロガー
26
+ LOGGER = Output::Logger.new(location: 'specifier')
27
+
28
+ class << self
29
+ #
30
+ # 取得する
31
+ #
32
+ # @param [Context::Context] context 暦コンテキスト
33
+ # @param [Array<Calculation::Base::Year>] years 範囲
34
+ # @param [Western::Calendar] start_date 西暦開始日
35
+ # @param [Western::Calendar] last_date 西暦終了日
36
+ #
37
+ # @return [Array<Result::Data::SingleDay>] 期間検索結果(和暦日)
38
+ #
39
+ def get(context:, years: [], start_date: Western::Calendar.new,
40
+ last_date: Western::Calendar.new)
41
+ months = specify(
42
+ context: context, years: years, start_date: start_date, last_date: last_date
43
+ )
44
+
45
+ result = []
46
+ months.each do |month|
47
+ result |= month.get
48
+ end
49
+
50
+ result
51
+ end
52
+
53
+ private
54
+
55
+ #
56
+ # 年を特定する
57
+ #
58
+ # @param [Context::Context] context 暦コンテキスト
59
+ # @param [Array<Calculation::Base::Year>] years 範囲
60
+ # @param [Western::Calendar] start_date 西暦開始日
61
+ # @param [Western::Calendar] last_date 西暦終了日
62
+ #
63
+ # @return [Array<Month>] 特定月
64
+ #
65
+ def specify(context:, years: [], start_date: Western::Calendar.new,
66
+ last_date: Western::Calendar.new)
67
+ result = []
68
+ years.each do |year|
69
+ result |= specify_month(
70
+ context: context, year: year, start_date: start_date, last_date: last_date
71
+ )
72
+ end
73
+
74
+ result
75
+ end
76
+
77
+ # :reek:TooManyStatements { max_statements: 7 }
78
+
79
+ #
80
+ # 月を特定する
81
+ #
82
+ # @param [Context::Context] context 暦コンテキスト
83
+ # @param [Calculation::Base::Year] year 年
84
+ # @param [Western::Calendar] start_date 西暦開始日
85
+ # @param [Western::Calendar] last_date 西暦終了日
86
+ #
87
+ # @return [Month] 対象月
88
+ #
89
+ def specify_month(context:, year:, start_date: Western::Calendar.new,
90
+ last_date: Western::Calendar.new)
91
+ months = year.months
92
+
93
+ specify_months = []
94
+ months.each do |month|
95
+ next unless include?(month: month, start_date: start_date, last_date: last_date)
96
+
97
+ monthly_start_date = month.western_date.clone
98
+ monthly_last_date = month.last_date.clone
99
+
100
+ monthly_start_date = start_date.clone if start_date > monthly_start_date
101
+
102
+ monthly_last_date = last_date.clone if last_date < monthly_last_date
103
+
104
+ specify_months.push(
105
+ Month.new(context: context, year: year, month: month,
106
+ start_date: monthly_start_date, last_date: monthly_last_date)
107
+ )
108
+ end
109
+
110
+ specify_months
111
+ end
112
+
113
+ #
114
+ # 月が範囲に含まれるか
115
+ #
116
+ # @param [Calculation::Monthly::Month] month 月
117
+ # @param [Western::Calendar] start_date 西暦開始日
118
+ # @param [Western::Calendar] last_date 西暦終了日
119
+ #
120
+ # @return [True] 含む
121
+ # @return [False] 含まない
122
+ #
123
+ def include?(month:, start_date:, last_date:)
124
+ monthly_start_date = month.western_date.clone
125
+ monthly_last_date = month.last_date.clone
126
+
127
+ return false if monthly_start_date.invalid?
128
+
129
+ return false if monthly_last_date.invalid?
130
+
131
+ return false if under(monthly_start_date: monthly_start_date,
132
+ start_date: start_date, last_date: last_date)
133
+
134
+ return false if over(monthly_last_date: monthly_last_date,
135
+ start_date: start_date, last_date: last_date)
136
+
137
+ true
138
+ end
139
+
140
+ #
141
+ # 範囲が月より前にあるか
142
+ #
143
+ # @param [Western::Calendar] monthly_start_date 月初日
144
+ # @param [Western::Calendar] start_date 西暦開始日
145
+ # @param [Western::Calendar] last_date 西暦終了日
146
+ #
147
+ # @return [True] 前にある
148
+ # @return [False] 前にない
149
+ #
150
+ def under(monthly_start_date:, start_date:, last_date:)
151
+ start_date < monthly_start_date && last_date < monthly_start_date
152
+ end
153
+
154
+ #
155
+ # 範囲が月より後にあるか
156
+ #
157
+ # @param [Western::Calendar] monthly_start_date 月末日
158
+ # @param [Western::Calendar] start_date 西暦開始日
159
+ # @param [Western::Calendar] last_date 西暦終了日
160
+ #
161
+ # @return [True] 後にある
162
+ # @return [False] 後にない
163
+ #
164
+ def over(monthly_last_date:, start_date:, last_date:)
165
+ start_date > monthly_last_date && last_date > monthly_last_date
166
+ end
167
+ end
168
+ end
169
+ end
170
+ end
171
+ end
172
+ end
173
+ end
@@ -0,0 +1,100 @@
1
+ # frozen_string_literal: true
2
+
3
+ require_relative '../../../../era/western/calendar'
4
+ require_relative '../../../../output/response'
5
+ require_relative '../../../../output/logger'
6
+
7
+ require_relative '../../../base/year'
8
+
9
+ require_relative '../../internal/day'
10
+ require_relative '../../internal/option'
11
+
12
+ # :nodoc:
13
+ module Zakuro
14
+ # :nodoc:
15
+ module Calculation
16
+ # :nodoc:
17
+ module Summary
18
+ # :nodoc:
19
+ module Western
20
+ # :nodoc:
21
+ module Specifier
22
+ #
23
+ # SingleDay 一日検索
24
+ #
25
+ module SingleDay
26
+ # @return [Output::Logger] ロガー
27
+ LOGGER = Output::Logger.new(location: 'specifier')
28
+
29
+ class << self
30
+ #
31
+ # 取得する
32
+ #
33
+ # @param [Array<Calculation::Base::Year>] years 範囲
34
+ # @param [Western::Calendar] date 西暦日
35
+ #
36
+ # @return [Result::Data::SingleDay] 和暦日
37
+ #
38
+ def get(years: [], date: Western::Calendar.new)
39
+ year, month = specify(years: years, date: date)
40
+
41
+ day = Day.get(month: month, date: date)
42
+
43
+ options = Option.create(month: month, day: day)
44
+
45
+ Output::Response::SingleDay.create(
46
+ year: year, month: month, day: day, options: options
47
+ )
48
+ end
49
+
50
+ private
51
+
52
+ #
53
+ # 年を特定する
54
+ #
55
+ # @param [Array<Year>] years 範囲
56
+ # @param [Western::Calendar] date 西暦日
57
+ #
58
+ # @return [Base::Year] 対象年
59
+ # @return [Monthly::Month] 対象月
60
+ #
61
+ # @raise [ArgumentError] 引数エラー
62
+ #
63
+ def specify(years:, date:)
64
+ years.each do |year|
65
+ month = specify_month(year: year, date: date)
66
+ return year, month unless month.invalid?
67
+ end
68
+
69
+ raise ArgumentError, "invalid year range. date: #{date.format}"
70
+ end
71
+
72
+ # :reek:TooManyStatements { max_statements: 7 }
73
+
74
+ #
75
+ # 月を特定する
76
+ #
77
+ # @param [Base::Year] year 年
78
+ # @param [Western::Calendar] date 西暦日
79
+ #
80
+ # @return [Monthly::Month] 対象月
81
+ #
82
+ def specify_month(year:, date:)
83
+ months = year.months
84
+
85
+ months.each do |month|
86
+ western_date = month.western_date
87
+ next if western_date.invalid?
88
+
89
+ return month if month.include?(date: date)
90
+ end
91
+
92
+ Monthly::Month.new
93
+ end
94
+ end
95
+ end
96
+ end
97
+ end
98
+ end
99
+ end
100
+ end
@@ -42,7 +42,7 @@ module Zakuro
42
42
  # @return [Float] 絶対値
43
43
  #
44
44
  def floor
45
- @abs.floor
45
+ abs.floor
46
46
  end
47
47
 
48
48
  #
@@ -51,7 +51,7 @@ module Zakuro
51
51
  # @return [Float] 符号つき浮動小数点数
52
52
  #
53
53
  def get
54
- @sign * @abs
54
+ sign * abs
55
55
  end
56
56
 
57
57
  #
@@ -0,0 +1,46 @@
1
+ # frozen_string_literal: true
2
+
3
+ # :nodoc:
4
+ module Zakuro
5
+ # :nodoc:
6
+ module Calculation
7
+ # :nodoc:
8
+ module Type
9
+ #
10
+ # Optional 参照管理
11
+ #
12
+ # * インスタンスのnil操作を避ける
13
+ # * safe navigation operator を使用しない
14
+ #
15
+ class Optional
16
+ #
17
+ # 初期化
18
+ #
19
+ # @param [Object] obj インスタンス
20
+ #
21
+ def initialize(obj: nil)
22
+ @obj = obj
23
+ end
24
+
25
+ #
26
+ # インスタンスを取得する
27
+ #
28
+ # @return [Object] インスタンス
29
+ #
30
+ def get
31
+ @obj
32
+ end
33
+
34
+ #
35
+ # 不正か
36
+ #
37
+ # @return [True] 不正
38
+ # @return [False] 不正なし
39
+ #
40
+ def invalid?
41
+ @obj.nil?
42
+ end
43
+ end
44
+ end
45
+ end
46
+ end