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
@@ -1,220 +0,0 @@
1
- # frozen_string_literal: true
2
-
3
- require_relative '../../operation/operation'
4
- require_relative '../monthly/month'
5
-
6
- # TODO: solar_termの中はsrc/destだが、yamlはcalc/actual。統一したい。
7
-
8
- # :nodoc:
9
- module Zakuro
10
- # :nodoc:
11
- module Calculation
12
- # :nodoc:
13
- module Range
14
- #
15
- # OperatedSolarTerm 運用時二十四節気
16
- #
17
- class OperatedSolarTerms
18
- # @return [Array<Year>] 完全範囲(年データ)
19
- attr_reader :years
20
- # @return [Hash<String, SolarTerm>] 二十四節気の移動元/移動先(西暦日 -> 対応する二十四節気)
21
- #
22
- # * 移動元の二十四節気:無効な大余小余あり(削除対象)
23
- # * 移動先の二十四節気:移動元からの二十四節気(追加対象)
24
- #
25
- attr_reader :directions
26
- # @return [Context] 暦コンテキスト
27
- attr_reader :context
28
-
29
- #
30
- # 初期化
31
- #
32
- # @param [Context] context 暦コンテキスト
33
- # @param [Array<Year>] years 完全範囲(年データ)
34
- #
35
- def initialize(context:, years: [])
36
- @context = context
37
- @years = years
38
- @directions = {}
39
- end
40
-
41
- #
42
- # データ生成する
43
- #
44
- # @return [<Type>] <description>
45
- #
46
- def create
47
- @directions = create_directions
48
- end
49
-
50
- #
51
- # 二十四節気を取得する
52
- #
53
- # @param [Western::Calendar] western_date 月初日の西暦日
54
- #
55
- # @return [True] 対象あり
56
- # @return [False] 対象なし
57
- # @return [SolarTerm] 二十四節気
58
- #
59
- def get(western_date: Western::Calendar.new)
60
- context = current_context(western_date: western_date)
61
-
62
- solar_term_class = context.resolver.solar_term
63
- solar_term = @directions.fetch(western_date.format, solar_term_class.new)
64
-
65
- # 合致しない場合
66
- return false, solar_term_class.new if solar_term.empty?
67
-
68
- # 合致した上で、二十四節気が移動元(削除対象)の場合
69
- # 合致した上で、二十四節気が移動先(追加対象)の場合
70
- [true, solar_term]
71
- end
72
-
73
- # :reek:TooManyStatements { max_statements: 6 }
74
-
75
- #
76
- # 年内の全ての月の移動方向を作成する
77
- #
78
- # @param [Context] context 暦コンテキスト
79
- # @param [Hash<String, SolarTerm>] directions 二十四節気の移動元/移動先(西暦日 -> 対応する二十四節気)
80
- # @param [Array<Month>] months 年内の全ての月
81
- #
82
- def self.create_directions_with_months(context:, directions: {}, months: [])
83
- months.each do |month|
84
- history = Operation.specify_history(western_date: month.western_date)
85
-
86
- next if history.invalid?
87
-
88
- direction = history.diffs.solar_term
89
-
90
- next if direction.invalid?
91
-
92
- OperatedSolarTerms.create_directions_each_month(
93
- context: context, directions: directions, direction: direction, month: month
94
- )
95
- end
96
- end
97
-
98
- # :reek:LongParameterList {max_params: 4}
99
-
100
- #
101
- # 月毎の移動方向を作成する
102
- #
103
- # @param [Context] context 暦コンテキスト
104
- # @param [Month] 月
105
- # @param [Hash<String, SolarTerm>] directions 二十四節気の移動元/移動先(西暦日 -> 対応する二十四節気)
106
- # @param [Operation::SolarTerm::Diretion] 二十四節気(移動)
107
- #
108
- def self.create_directions_each_month(context:, month:, directions: {},
109
- direction: Operation::SolarTerm::Diretion.new)
110
-
111
- month.solar_terms.each do |solar_term|
112
- OperatedSolarTerms.push_source(context: context, directions: directions,
113
- direction: direction, solar_term: solar_term)
114
- end
115
- OperatedSolarTerms.push_destination(context: context, directions: directions,
116
- destination: direction.destination)
117
- end
118
-
119
- # :reek:LongParameterList {max_params: 4}
120
-
121
- #
122
- # 移動先に有効な二十四節気(差し替える二十四節気)を指定する
123
- #
124
- # @param [Context] context 暦コンテキスト
125
- # @param [SolarTerm] solar_term 二十四節気(計算値)
126
- # @param [Hash<String, SolarTerm>] directions 二十四節気の移動元/移動先(西暦日 -> 対応する二十四節気)
127
- # @param [Operation::SolarTerm::Direction] source 二十四節気(移動)
128
- #
129
- def self.push_source(context:, solar_term:, directions: {},
130
- direction: Operation::SolarTerm::Direction.new)
131
- source = direction.source
132
-
133
- return if source.invalid?
134
-
135
- return unless source.index == solar_term.index
136
-
137
- # 移動先に移動元の二十四節気を指定する
138
- directions[source.to.format] = OperatedSolarTerms.created_source(
139
- context: context, direction: direction, solar_term: solar_term
140
- )
141
- end
142
-
143
- #
144
- # 移動先に有効な二十四節気(差し替える二十四節気)を生成する
145
- #
146
- # @param [Context] context 暦コンテキスト
147
- # @param [SolarTerm] solar_term 二十四節気(計算値)
148
- # @param [Operation::SolarTerm::Direction] source 二十四節気(移動)
149
- #
150
- # @return [SolarTerm] 二十四節気(運用値)
151
- #
152
- def self.created_source(context:, solar_term:,
153
- direction: Operation::SolarTerm::Direction.new)
154
- operated_solar_term = solar_term.clone
155
- remainder_class_name = context.resolver.remainder
156
-
157
- unless direction.invalid_days?
158
- # 二十四節気の大余をずらす
159
- operated_solar_term.remainder.add!(
160
- remainder_class_name.new(day: direction.days, minute: 0, second: 0)
161
- )
162
- end
163
-
164
- operated_solar_term
165
- end
166
-
167
- #
168
- # 移動元に無効な二十四節気(連番のみ指定)を指定する
169
- #
170
- # @param [Context] context 暦コンテキスト
171
- # @param [Hash<String, SolarTerm>] directions 二十四節気の移動元/移動先(西暦日 -> 対応する二十四節気)
172
- # @param [Operation::SolarTerm::Destination] destination 二十四節気(移動先)
173
- #
174
- def self.push_destination(context:, directions: {},
175
- destination: Operation::SolarTerm::Destination.new)
176
- return if destination.invalid?
177
-
178
- solar_term_class = context.resolver.solar_term
179
- directions[destination.from.format] = solar_term_class.new(
180
- index: destination.index
181
- )
182
- end
183
-
184
- private
185
-
186
- #
187
- # 日付に対応する暦コンテキストを取得する
188
- #
189
- # @param [Western::Calendar] western_date 西暦日
190
- #
191
- # @return [Context] 暦コンテキスト
192
- #
193
- def current_context(western_date: Western::Calendar.new)
194
- @years.each do |year|
195
- return year.context if western_date >= year.new_year_date
196
- end
197
-
198
- Context.new
199
- end
200
-
201
- #
202
- # 二十四節気の移動元/移動先を生成する
203
- #
204
- # @return [Hash<String, SolarTerm>] 二十四節気の移動元/移動先(西暦日 -> 対応する二十四節気)
205
- #
206
- def create_directions
207
- directions = {}
208
-
209
- years.each do |year|
210
- OperatedSolarTerms.create_directions_with_months(
211
- context: year.context, directions: directions, months: year.months
212
- )
213
- end
214
-
215
- directions
216
- end
217
- end
218
- end
219
- end
220
- end
@@ -1,162 +0,0 @@
1
- # frozen_string_literal: true
2
-
3
- require_relative '../base/year'
4
-
5
- require_relative '../../era/western/calendar'
6
- require_relative '../../output/response'
7
- require_relative '../../output/logger'
8
-
9
- require_relative './internal/month'
10
-
11
- # :nodoc:
12
- module Zakuro
13
- # :nodoc:
14
- module Calculation
15
- # :nodoc:
16
- module Specifier
17
- #
18
- # MultipleDay 複数日検索
19
- #
20
- module MultipleDay
21
- # @return [Output::Logger] ロガー
22
- LOGGER = Output::Logger.new(location: 'specifier')
23
-
24
- #
25
- # 取得する
26
- #
27
- # @param [Array<Base::Year>] years 範囲
28
- # @param [Western::Calendar] start_date 西暦開始日
29
- # @param [Western::Calendar] last_date 西暦終了日
30
- #
31
- # @return [Array<Result::Data::SingleDay>] 期間検索結果(和暦日)
32
- #
33
- def self.get(years: [], start_date: Western::Calendar.new, last_date: Western::Calendar.new)
34
- months = specify(years: years, start_date: start_date, last_date: last_date)
35
-
36
- result = []
37
- months.each do |month|
38
- result |= month.get
39
- end
40
-
41
- result
42
- end
43
-
44
- #
45
- # 年を特定する
46
- #
47
- # @param [Array<Year>] years 範囲
48
- # @param [Western::Calendar] start_date 西暦開始日
49
- # @param [Western::Calendar] last_date 西暦終了日
50
- #
51
- # @return [Array<Month>] 特定月
52
- #
53
- def self.specify(years: [], start_date: Western::Calendar.new,
54
- last_date: Western::Calendar.new)
55
- result = []
56
- years.each do |year|
57
- result |= specify_month(
58
- year: year, start_date: start_date, last_date: last_date
59
- )
60
- end
61
-
62
- result
63
- end
64
- private_class_method :specify
65
-
66
- # :reek:TooManyStatements { max_statements: 7 }
67
-
68
- #
69
- # 月を特定する
70
- #
71
- # @param [Year] year 年
72
- # @param [Western::Calendar] start_date 西暦開始日
73
- # @param [Western::Calendar] last_date 西暦終了日
74
- #
75
- # @return [Month] 対象月
76
- #
77
- def self.specify_month(year:, start_date: Western::Calendar.new,
78
- last_date: Western::Calendar.new)
79
- months = year.months
80
-
81
- specify_months = []
82
- months.each do |month|
83
- next unless include?(month: month, start_date: start_date, last_date: last_date)
84
-
85
- monthly_start_date = month.western_date.clone
86
- monthly_last_date = month.last_date.clone
87
-
88
- monthly_start_date = start_date.clone if start_date > monthly_start_date
89
-
90
- monthly_last_date = last_date.clone if last_date < monthly_last_date
91
-
92
- specify_months.push(
93
- Month.new(year: year, month: month,
94
- start_date: monthly_start_date, last_date: monthly_last_date)
95
- )
96
- end
97
-
98
- specify_months
99
- end
100
- private_class_method :specify_month
101
-
102
- #
103
- # 月が範囲に含まれるか
104
- #
105
- # @param [Monthly::Month] month 月
106
- # @param [Western::Calendar] start_date 西暦開始日
107
- # @param [Western::Calendar] last_date 西暦終了日
108
- #
109
- # @return [True] 含む
110
- # @return [False] 含まない
111
- #
112
- def self.include?(month:, start_date:, last_date:)
113
- monthly_start_date = month.western_date.clone
114
- monthly_last_date = month.last_date.clone
115
-
116
- return false if monthly_start_date.invalid?
117
-
118
- return false if monthly_last_date.invalid?
119
-
120
- return false if under(monthly_start_date: monthly_start_date,
121
- start_date: start_date, last_date: last_date)
122
-
123
- return false if over(monthly_last_date: monthly_last_date,
124
- start_date: start_date, last_date: last_date)
125
-
126
- true
127
- end
128
- private_class_method :include?
129
-
130
- #
131
- # 範囲が月より前にあるか
132
- #
133
- # @param [Western::Calendar] monthly_start_date 月初日
134
- # @param [Western::Calendar] start_date 西暦開始日
135
- # @param [Western::Calendar] last_date 西暦終了日
136
- #
137
- # @return [True] 前にある
138
- # @return [False] 前にない
139
- #
140
- def self.under(monthly_start_date:, start_date:, last_date:)
141
- start_date < monthly_start_date && last_date < monthly_start_date
142
- end
143
- private_class_method :under
144
-
145
- #
146
- # 範囲が月より後にあるか
147
- #
148
- # @param [Western::Calendar] monthly_start_date 月末日
149
- # @param [Western::Calendar] start_date 西暦開始日
150
- # @param [Western::Calendar] last_date 西暦終了日
151
- #
152
- # @return [True] 後にある
153
- # @return [False] 後にない
154
- #
155
- def self.over(monthly_last_date:, start_date:, last_date:)
156
- start_date > monthly_last_date && last_date > monthly_last_date
157
- end
158
- private_class_method :over
159
- end
160
- end
161
- end
162
- end
@@ -1,87 +0,0 @@
1
- # frozen_string_literal: true
2
-
3
- require_relative '../base/year'
4
-
5
- require_relative '../../era/western/calendar'
6
- require_relative '../../output/response'
7
- require_relative '../../output/logger'
8
-
9
- # :nodoc:
10
- module Zakuro
11
- # :nodoc:
12
- module Calculation
13
- # :nodoc:
14
- module Specifier
15
- #
16
- # SingleDay 一日検索
17
- #
18
- module SingleDay
19
- # @return [Output::Logger] ロガー
20
- LOGGER = Output::Logger.new(location: 'specifier')
21
-
22
- #
23
- # 取得する
24
- #
25
- # @param [Array<Year>] yeas 範囲
26
- # @param [Western::Calendar] date 西暦日
27
- #
28
- # @return [Result::Data::SingleDay] 和暦日
29
- #
30
- def self.get(years: [], date: Western::Calendar.new)
31
- year, month = specify(years: years, date: date)
32
- first_date = month.western_date
33
-
34
- Output::Response::SingleDay.save_single_day(
35
- param: Output::Response::SingleDay::Param.new(
36
- year: year, month: month,
37
- date: date, days: date - first_date
38
- )
39
- )
40
- end
41
-
42
- #
43
- # 年を特定する
44
- #
45
- # @param [Array<Year>] years 範囲
46
- # @param [Western::Calendar] date 西暦日
47
- #
48
- # @return [Base::Year] 対象年
49
- # @return [Base::Month] 対象月
50
- #
51
- def self.specify(years:, date:)
52
- years.each do |year|
53
- month = specify_month(year: year, date: date)
54
- return year, month unless month.invalid?
55
- end
56
-
57
- raise ArgumentError, "invalid year range. date: #{date.format}"
58
- end
59
- private_class_method :specify
60
-
61
- # :reek:TooManyStatements { max_statements: 7 }
62
-
63
- #
64
- # 月を特定する
65
- #
66
- # @param [Base::Year] year 年
67
- # @param [Western::Calendar] date 西暦日
68
- #
69
- # @return [Base::Month] 対象月
70
- #
71
- def self.specify_month(year:, date:)
72
- months = year.months
73
-
74
- months.each do |month|
75
- western_date = month.western_date
76
- next if western_date.invalid?
77
-
78
- return month if month.include?(date: date)
79
- end
80
-
81
- Monthly::Month.new
82
- end
83
- private_class_method :specify_month
84
- end
85
- end
86
- end
87
- end
@@ -1,120 +0,0 @@
1
- # frozen_string_literal: true
2
-
3
- require_relative '../specifier/multiple_day'
4
-
5
- require_relative '../range/operated_range'
6
-
7
- require_relative '../range/full_range'
8
-
9
- require_relative './internal/operation'
10
-
11
- # :nodoc:
12
- module Zakuro
13
- # :nodoc:
14
- module Calculation
15
- # :nodoc:
16
- module Summary
17
- #
18
- # Range 期間
19
- #
20
- module Range
21
- #
22
- # 生成する
23
- #
24
- # @param [Context] context 暦コンテキスト
25
- # @param [Western::Calendar] start_date 西暦開始日
26
- # @param [Western::Calendar] last_date 西暦終了日
27
- #
28
- # @return [Result::Range] 期間検索結果(和暦日)
29
- #
30
- def self.get(context:, start_date: Western::Calendar.new, last_date: Western::Calendar.new)
31
- years = get_full_range_years(
32
- context: context, start_date: start_date, last_date: last_date
33
- )
34
- operated_years = get_operated_range_years(
35
- context: context, years: years, start_date: start_date, last_date: last_date
36
- )
37
-
38
- dates = Specifier::MultipleDay.get(
39
- years: years, start_date: start_date, last_date: last_date
40
- )
41
-
42
- operated_dates = Specifier::MultipleDay.get(
43
- years: operated_years, start_date: start_date, last_date: last_date
44
- )
45
-
46
- list = create_result_list(dates: dates, operated_dates: operated_dates)
47
-
48
- Result::Range.new(list: list)
49
- end
50
-
51
- #
52
- # 完全範囲を取得する
53
- #
54
- # @param [Context] context 暦コンテキスト
55
- # @param [Western::Calendar] start_date 西暦開始日
56
- # @param [Western::Calendar] last_date 西暦終了日
57
- #
58
- # @return [Array<Base::Year>] 完全範囲
59
- #
60
- def self.get_full_range_years(context:, start_date: Western::Calendar.new,
61
- last_date: Western::Calendar.new)
62
- full_range = Calculation::Range::FullRange.new(
63
- context: context, start_date: start_date, last_date: last_date
64
- )
65
- full_range.get
66
- end
67
- private_class_method :get_full_range_years
68
-
69
- #
70
- # 運用結果範囲を取得する
71
- #
72
- # @param [Context] context 暦コンテキスト
73
- # @param [Western::Calendar] start_date 西暦開始日
74
- # @param [Western::Calendar] last_date 西暦終了日
75
- # @param [Western::Calendar] date 西暦日
76
- #
77
- # @return [Array<Base::OperatedYear>] 運用結果範囲
78
- #
79
- def self.get_operated_range_years(context:, years:, start_date: Western::Calendar.new,
80
- last_date: Western::Calendar.new)
81
- operated_range = Calculation::Range::OperatedRange.new(
82
- context: context, start_date: start_date, last_date: last_date, years: years
83
- )
84
- operated_range.get
85
- end
86
- private_class_method :get_operated_range_years
87
-
88
- #
89
- # 結果リストを生成する
90
- #
91
- # @param [Array<Result::Data::SingleDay>] dates 検索結果(計算値)
92
- # @param [Array<Result::Data::SingleDay>] operated_dates 検索結果(運用値)
93
- #
94
- # @return [Array<Result::Single>] 結果リスト
95
- #
96
- def self.create_result_list(dates:, operated_dates:)
97
- result = []
98
-
99
- return result if dates.size != operated_dates.size
100
-
101
- (0..(dates.size - 1)).each do |index|
102
- data = operated_dates[index]
103
-
104
- date = dates[index]
105
- operation = Operation.create(calc_date: date)
106
-
107
- result.push(
108
- Result::Single.new(
109
- data: data,
110
- operation: operation
111
- )
112
- )
113
- end
114
-
115
- result
116
- end
117
- end
118
- end
119
- end
120
- end
@@ -1,110 +0,0 @@
1
- # frozen_string_literal: true
2
-
3
- require_relative '../specifier/single_day'
4
-
5
- require_relative '../range/operated_range'
6
-
7
- require_relative '../range/full_range'
8
-
9
- require_relative './internal/operation'
10
-
11
- # :nodoc:
12
- module Zakuro
13
- # :nodoc:
14
- module Calculation
15
- # :nodoc:
16
- module Summary
17
- #
18
- # Single 一日
19
- #
20
- module Single
21
- #
22
- # 生成する
23
- #
24
- # @param [Context] context 暦コンテキスト
25
- # @param [Western::Calendar] date 西暦日
26
- #
27
- # @return [Result::Single] 一日検索結果(和暦日)
28
- #
29
- def self.get(context:, date: Western::Calendar.new)
30
- years = get_full_range_years(context: context, date: date)
31
-
32
- data = get_data(context: context, years: years, date: date)
33
-
34
- operation = get_operation(years: years, date: date)
35
-
36
- Result::Single.new(
37
- data: data,
38
- operation: operation
39
- )
40
- end
41
-
42
- #
43
- # 完全範囲を取得する
44
- #
45
- # @param [Context] context 暦コンテキスト
46
- # @param [Western::Calendar] date 西暦日
47
- #
48
- # @return [Array<Base::Year>] 完全範囲
49
- #
50
- def self.get_full_range_years(context:, date: Western::Calendar.new)
51
- full_range = Calculation::Range::FullRange.new(context: context, start_date: date)
52
- full_range.get
53
- end
54
- private_class_method :get_full_range_years
55
-
56
- #
57
- # 運用結果範囲を取得する
58
- #
59
- # @param [Context] context 暦コンテキスト
60
- # @param [Array<Base::Year>] years 完全範囲
61
- # @param [Western::Calendar] date 西暦日
62
- #
63
- # @return [Array<Base::OperatedYear>] 運用結果範囲
64
- #
65
- def self.get_operated_range_years(context:, years:, date: Western::Calendar.new)
66
- operated_range = Calculation::Range::OperatedRange.new(
67
- context: context, start_date: date, years: years
68
- )
69
- operated_range.get
70
- end
71
- private_class_method :get_operated_range_years
72
-
73
- #
74
- # 1日を取得する
75
- #
76
- # @param [Context] context 暦コンテキスト
77
- # @param [Array<Base::Year>] years 完全範囲
78
- # @param [Western::Calendar] date 西暦日
79
- #
80
- # @return [Data::SingleDay] 1日
81
- #
82
- def self.get_data(context:, years:, date: Western::Calendar.new)
83
- operated_years = get_operated_range_years(context: context, years: years, date: date)
84
-
85
- Calculation::Specifier::SingleDay.get(
86
- years: operated_years, date: date
87
- )
88
- end
89
- private_class_method :get_data
90
-
91
- #
92
- # 完全範囲を取得する
93
- #
94
- # @param [Context] context 暦コンテキスト
95
- # @param [Western::Calendar] date 西暦日
96
- #
97
- # @return [Array<Base::Year>] 完全範囲
98
- #
99
- def self.get_operation(years:, date: Western::Calendar.new)
100
- calc_date = Calculation::Specifier::SingleDay.get(
101
- years: years, date: date
102
- )
103
-
104
- Operation.create(calc_date: calc_date)
105
- end
106
- private_class_method :get_operation
107
- end
108
- end
109
- end
110
- end