zakuro 0.9.4 → 1.0.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/Gemfile +2 -2
- data/README.md +41 -8
- data/VERSION +1 -1
- data/doc/gengou.md +1 -1
- data/doc/operation/csv/month.csv +5 -5
- data/doc/operation/operation.xlsx +0 -0
- data/images/logo-text.png +0 -0
- data/lib/zakuro/calculation/base/gengou.rb +2 -4
- data/lib/zakuro/calculation/base/year.rb +1 -1
- data/lib/zakuro/calculation/era/gengou/abstract_scroll.rb +2 -2
- data/lib/zakuro/calculation/era/gengou/internal/publisher.rb +1 -1
- data/lib/zakuro/calculation/era/gengou/internal/reserve/abstract_list.rb +4 -4
- data/lib/zakuro/calculation/era/gengou/internal/reserve/empty_link.rb +3 -3
- data/lib/zakuro/calculation/era/gengou/internal/reserve/named_list.rb +1 -1
- data/lib/zakuro/calculation/era/version/internal/crawler.rb +3 -3
- data/lib/zakuro/calculation/monthly/abstract_lunar_phase.rb +1 -1
- data/lib/zakuro/calculation/monthly/internal/date_comparer.rb +78 -0
- data/lib/zakuro/calculation/monthly/{meta → internal/meta}/all_solar_term.rb +1 -1
- data/lib/zakuro/calculation/monthly/{meta → internal/meta}/meta_collector.rb +2 -2
- data/lib/zakuro/calculation/monthly/{first_day.rb → internal/part/first_day.rb} +2 -2
- data/lib/zakuro/calculation/monthly/{meta.rb → internal/part/meta.rb} +1 -1
- data/lib/zakuro/calculation/monthly/internal/solar_term_selector.rb +203 -0
- data/lib/zakuro/calculation/monthly/month.rb +30 -125
- data/lib/zakuro/calculation/monthly/operated_month.rb +5 -2
- data/lib/zakuro/calculation/range/medieval_annual_range.rb +0 -2
- data/lib/zakuro/calculation/range/transfer/gengou_scroller.rb +24 -10
- data/lib/zakuro/calculation/stella/solar/abstract_average.rb +3 -3
- data/lib/zakuro/calculation/summary/internal/option/dropped_date.rb +102 -0
- data/lib/zakuro/calculation/summary/internal/option/vanished_date.rb +111 -0
- data/lib/zakuro/calculation/summary/internal/option.rb +4 -137
- data/lib/zakuro/calculation/summary/japan/range.rb +4 -5
- data/lib/zakuro/calculation/summary/western/single.rb +0 -2
- data/lib/zakuro/context/version_class_resolver.rb +5 -5
- data/lib/zakuro/era/japan/calendar.rb +4 -4
- data/lib/zakuro/era/japan/gengou/alignment/division.rb +2 -2
- data/lib/zakuro/era/japan/gengou/alignment/linear_gengou.rb +2 -2
- data/lib/zakuro/era/japan/gengou/alignment.rb +5 -3
- data/lib/zakuro/era/japan/gengou/resource/parser.rb +17 -16
- data/lib/zakuro/era/japan/gengou/resource/validator.rb +3 -394
- data/lib/zakuro/era/japan/gengou/resource/yaml/set-001-until-south.yaml +2 -2
- data/lib/zakuro/era/japan/gengou.rb +3 -3
- data/lib/zakuro/era/japan/type/base/both/date.rb +51 -0
- data/lib/zakuro/era/japan/type/base/both/year.rb +53 -0
- data/lib/zakuro/era/japan/type/base/gengou.rb +177 -0
- data/lib/zakuro/era/japan/type/base/gengou_set.rb +78 -0
- data/lib/zakuro/era/japan/type/base/switch_date.rb +74 -0
- data/lib/zakuro/era/japan/type/base/version_range.rb +189 -0
- data/lib/zakuro/era/japan/type/validation/both/date.rb +99 -0
- data/lib/zakuro/era/japan/type/validation/both/year.rb +75 -0
- data/lib/zakuro/era/japan/type/validation/gengou.rb +93 -0
- data/lib/zakuro/era/japan/type/validation/gengou_set.rb +133 -0
- data/lib/zakuro/era/japan/type/validation/switch_date.rb +73 -0
- data/lib/zakuro/era/japan/type/validation/version_range.rb +109 -0
- data/lib/zakuro/era/japan/type/validation/version_root.rb +102 -0
- data/lib/zakuro/era/japan/version/resource/parser.rb +266 -0
- data/lib/zakuro/era/japan/version/resource/validator.rb +37 -0
- data/lib/zakuro/era/japan/version/resource/yaml/version.yaml +80 -0
- data/lib/zakuro/era/japan/version/resource.rb +22 -0
- data/lib/zakuro/era/japan/version.rb +4 -115
- data/lib/zakuro/era/western/calendar.rb +2 -2
- data/lib/zakuro/exception/zakuro_error.rb +1 -1
- data/lib/zakuro/merchant.rb +5 -5
- data/lib/zakuro/operation/month/parser.rb +2 -2
- data/lib/zakuro/operation/yaml/month.yaml +5 -5
- data/lib/zakuro/output/logger.rb +4 -4
- data/lib/zakuro/parameter/catalog/basis_date.rb +55 -0
- data/lib/zakuro/parameter/catalog/column.rb +57 -0
- data/lib/zakuro/parameter/catalog/option.rb +60 -0
- data/lib/zakuro/parameter/catalog/range.rb +81 -0
- data/lib/zakuro/parameter/condition.rb +108 -0
- data/lib/zakuro/result/core.rb +2 -2
- data/lib/zakuro/{tools → tool}/remainder_comparer.rb +2 -4
- data/lib/zakuro/{tools → tool}/stringifier.rb +3 -3
- data/lib/zakuro/{tools → tool}/typeconv.rb +2 -2
- data/lib/zakuro/{tools → tool}/typeof.rb +2 -2
- data/lib/zakuro/version/daien/const/number.rb +42 -39
- data/lib/zakuro/version/daien/const/remainder.rb +38 -35
- data/lib/zakuro/version/daien/cycle/remainder.rb +77 -74
- data/lib/zakuro/version/daien/cycle/solar_term.rb +18 -15
- data/lib/zakuro/version/daien/daien.rb +8 -5
- data/lib/zakuro/version/daien/monthly/lunar_phase.rb +67 -64
- data/lib/zakuro/version/daien/option/dropped_date/parameter.rb +15 -12
- data/lib/zakuro/version/daien/option/vanished_date/parameter.rb +15 -12
- data/lib/zakuro/version/daien/range/annual_range.rb +27 -24
- data/lib/zakuro/version/daien/stella/lunar/adjustment.rb +209 -206
- data/lib/zakuro/version/daien/stella/lunar/localization.rb +32 -29
- data/lib/zakuro/version/daien/stella/lunar/location.rb +53 -50
- data/lib/zakuro/version/daien/stella/lunar/value.rb +65 -62
- data/lib/zakuro/version/daien/stella/origin/average_november.rb +23 -20
- data/lib/zakuro/version/daien/stella/origin/lunar_age.rb +42 -39
- data/lib/zakuro/version/daien/stella/origin/winter_solstice.rb +44 -41
- data/lib/zakuro/version/daien/stella/solar/adjustment.rb +74 -71
- data/lib/zakuro/version/daien/stella/solar/average.rb +68 -65
- data/lib/zakuro/version/daien/stella/solar/interval.rb +95 -92
- data/lib/zakuro/version/daien/stella/solar/location.rb +41 -38
- data/lib/zakuro/version/daien/stella/solar/value.rb +21 -18
- data/lib/zakuro/version/genka/const/number.rb +31 -28
- data/lib/zakuro/version/genka/const/remainder.rb +20 -17
- data/lib/zakuro/version/genka/cycle/remainder.rb +72 -69
- data/lib/zakuro/version/genka/cycle/solar_term.rb +18 -15
- data/lib/zakuro/version/genka/genka.rb +8 -5
- data/lib/zakuro/version/genka/monthly/lunar_phase.rb +82 -79
- data/lib/zakuro/version/genka/option/dropped_date/parameter.rb +13 -10
- data/lib/zakuro/version/genka/option/vanished_date/parameter.rb +13 -10
- data/lib/zakuro/version/genka/range/annual_range.rb +57 -54
- data/lib/zakuro/version/genka/stella/origin/first_term.rb +44 -41
- data/lib/zakuro/version/genka/stella/origin/january.rb +38 -35
- data/lib/zakuro/version/genka/stella/solar/average.rb +24 -21
- data/lib/zakuro/version/gihou/const/number.rb +40 -37
- data/lib/zakuro/version/gihou/const/remainder.rb +32 -29
- data/lib/zakuro/version/gihou/cycle/remainder.rb +38 -35
- data/lib/zakuro/version/gihou/cycle/solar_term.rb +18 -15
- data/lib/zakuro/version/gihou/gihou.rb +8 -5
- data/lib/zakuro/version/gihou/monthly/lunar_phase.rb +68 -65
- data/lib/zakuro/version/gihou/option/dropped_date/parameter.rb +13 -10
- data/lib/zakuro/version/gihou/option/vanished_date/parameter.rb +13 -10
- data/lib/zakuro/version/gihou/range/annual_range.rb +27 -24
- data/lib/zakuro/version/gihou/stella/lunar/adjustment.rb +212 -209
- data/lib/zakuro/version/gihou/stella/lunar/localization.rb +32 -29
- data/lib/zakuro/version/gihou/stella/lunar/location.rb +53 -50
- data/lib/zakuro/version/gihou/stella/lunar/value.rb +65 -62
- data/lib/zakuro/version/gihou/stella/origin/average_november.rb +23 -20
- data/lib/zakuro/version/gihou/stella/origin/lunar_age.rb +42 -39
- data/lib/zakuro/version/gihou/stella/origin/winter_solstice.rb +44 -41
- data/lib/zakuro/version/gihou/stella/solar/adjustment.rb +74 -71
- data/lib/zakuro/version/gihou/stella/solar/average.rb +67 -64
- data/lib/zakuro/version/gihou/stella/solar/interval.rb +95 -92
- data/lib/zakuro/version/gihou/stella/solar/location.rb +41 -38
- data/lib/zakuro/version/gihou/stella/solar/value.rb +21 -18
- data/lib/zakuro/version/gregorio/gregorio.rb +8 -5
- data/lib/zakuro/version/houryaku/houryaku.rb +8 -5
- data/lib/zakuro/version/joukyou/joukyou.rb +8 -5
- data/lib/zakuro/version/kansei/kansei.rb +8 -5
- data/lib/zakuro/version/senmyou/const/number.rb +40 -37
- data/lib/zakuro/version/senmyou/const/remainder.rb +35 -32
- data/lib/zakuro/version/senmyou/cycle/remainder.rb +74 -71
- data/lib/zakuro/version/senmyou/cycle/solar_term.rb +18 -15
- data/lib/zakuro/version/senmyou/monthly/lunar_phase.rb +69 -66
- data/lib/zakuro/version/senmyou/option/dropped_date/parameter.rb +15 -12
- data/lib/zakuro/version/senmyou/option/vanished_date/parameter.rb +15 -12
- data/lib/zakuro/version/senmyou/range/annual_range.rb +27 -24
- data/lib/zakuro/version/senmyou/senmyou.rb +8 -5
- data/lib/zakuro/version/senmyou/stella/lunar/adjustment.rb +206 -203
- data/lib/zakuro/version/senmyou/stella/lunar/localization.rb +32 -29
- data/lib/zakuro/version/senmyou/stella/lunar/location.rb +60 -57
- data/lib/zakuro/version/senmyou/stella/lunar/value.rb +66 -63
- data/lib/zakuro/version/senmyou/stella/origin/average_november.rb +23 -20
- data/lib/zakuro/version/senmyou/stella/origin/lunar_age.rb +42 -39
- data/lib/zakuro/version/senmyou/stella/origin/winter_solstice.rb +44 -41
- data/lib/zakuro/version/senmyou/stella/solar/adjustment.rb +74 -71
- data/lib/zakuro/version/senmyou/stella/solar/average.rb +67 -64
- data/lib/zakuro/version/senmyou/stella/solar/interval.rb +93 -90
- data/lib/zakuro/version/senmyou/stella/solar/location.rb +41 -38
- data/lib/zakuro/version/senmyou/stella/solar/value.rb +23 -20
- data/lib/zakuro/version/tenpou/tenpou.rb +8 -5
- metadata +44 -20
- data/lib/zakuro/condition.rb +0 -306
- data/lib/zakuro/era/japan/gengou/resource/type.rb +0 -356
- data/lib/zakuro/tools/gengou_range_comparer.rb +0 -82
- /data/lib/zakuro/calculation/monthly/{operated_solar_term.rb → internal/operated_solar_term.rb} +0 -0
- /data/lib/zakuro/calculation/monthly/{const.rb → internal/part/const.rb} +0 -0
- /data/lib/zakuro/calculation/monthly/{month_label.rb → internal/part/month_label.rb} +0 -0
@@ -1,12 +1,9 @@
|
|
1
1
|
# frozen_string_literal: true
|
2
2
|
|
3
3
|
require_relative '../../../context/option'
|
4
|
-
require_relative '../../../result/data/option/dropped_date/option'
|
5
|
-
require_relative '../../../result/data/solar_term'
|
6
|
-
require_relative '../../../result/data/option/vanished_date/option'
|
7
4
|
|
8
|
-
require_relative '
|
9
|
-
require_relative '
|
5
|
+
require_relative './option/dropped_date'
|
6
|
+
require_relative './option/vanished_date'
|
10
7
|
|
11
8
|
# :nodoc:
|
12
9
|
module Zakuro
|
@@ -28,153 +25,23 @@ module Zakuro
|
|
28
25
|
# @return [Hash<String, Result::Data::Option::AbstractOption>] オプション結果
|
29
26
|
#
|
30
27
|
def create(month:, day:)
|
31
|
-
# TODO: refactor
|
32
|
-
|
33
28
|
options = {}
|
34
29
|
context = month.context
|
35
30
|
|
36
31
|
if context.option.dropped_date?
|
37
|
-
|
32
|
+
option = DroppedDate.get(month: month, day: day)
|
38
33
|
|
39
|
-
remainder = day.remainder
|
40
|
-
option = dropped_date(
|
41
|
-
context: context, remainder: remainder, solar_term: solar_term
|
42
|
-
)
|
43
34
|
options[Context::Option::DROPPED_DATE_KEY] = option
|
44
35
|
end
|
45
36
|
|
46
|
-
# TODO: refactor
|
47
37
|
if context.option.vanished_date?
|
48
|
-
|
49
|
-
average_remainder = month.first_day.average_remainder
|
50
|
-
# p "remainder: #{remainder.format}"
|
51
|
-
# p "last_average_remainder: #{month.meta.last_average_remainder.format}"
|
52
|
-
|
53
|
-
if day.number == 1
|
54
|
-
option = vanished_date(
|
55
|
-
context: context, remainder: remainder,
|
56
|
-
average_remainder: month.meta.last_average_remainder
|
57
|
-
)
|
58
|
-
options[Context::Option::VANISHED_DATE_KEY] = option
|
59
|
-
|
60
|
-
return options if option.matched
|
61
|
-
end
|
38
|
+
option = VanishedDate.get(month: month, day: day)
|
62
39
|
|
63
|
-
option = vanished_date(
|
64
|
-
context: context, remainder: remainder, average_remainder: average_remainder
|
65
|
-
)
|
66
40
|
options[Context::Option::VANISHED_DATE_KEY] = option
|
67
41
|
end
|
68
42
|
|
69
43
|
options
|
70
44
|
end
|
71
|
-
|
72
|
-
private
|
73
|
-
|
74
|
-
#
|
75
|
-
# 没日を求める
|
76
|
-
#
|
77
|
-
# @param [Context::Context] context 暦コンテキスト
|
78
|
-
# @param [Cycle::AbstractRemainder] remainder 当日和暦日
|
79
|
-
# @param [Cycle::AbstractSolarTerm] solar_terms 二十四節気
|
80
|
-
#
|
81
|
-
# @return [Result::Data::Option::DroppedDate::Option] 没日
|
82
|
-
#
|
83
|
-
def dropped_date(context:, remainder:, solar_term:)
|
84
|
-
option = Result::Data::Option::DroppedDate::Option.new
|
85
|
-
|
86
|
-
return option if remainder.invalid?
|
87
|
-
|
88
|
-
location = Calculation::Option::DroppedDate::Location.new(
|
89
|
-
context: context, solar_term: solar_term
|
90
|
-
)
|
91
|
-
|
92
|
-
return option if location.invalid?
|
93
|
-
|
94
|
-
return option unless location.exist?
|
95
|
-
|
96
|
-
dropped_date = location.get
|
97
|
-
|
98
|
-
dropped_date_option(
|
99
|
-
matched: remainder.day == dropped_date.day, location: location
|
100
|
-
)
|
101
|
-
end
|
102
|
-
|
103
|
-
#
|
104
|
-
# 没日オプション値を生成する
|
105
|
-
#
|
106
|
-
# @param [True, False] matched 没日有無
|
107
|
-
# @param [Calculation::Option::DroppedDate::Location] location 没日位置
|
108
|
-
#
|
109
|
-
# @return [Result::Data::Option::DroppedDate::Option] 没日オプション値
|
110
|
-
#
|
111
|
-
def dropped_date_option(matched:, location:)
|
112
|
-
dropped_date = location.get
|
113
|
-
solar_term = location.solar_term
|
114
|
-
Result::Data::Option::DroppedDate::Option.new(
|
115
|
-
matched: matched,
|
116
|
-
calculation: Result::Data::Option::DroppedDate::Calculation.new(
|
117
|
-
remainder: dropped_date.format,
|
118
|
-
solar_term: Result::Data::SolarTerm.new(
|
119
|
-
index: solar_term.index,
|
120
|
-
remainder: solar_term.remainder.format
|
121
|
-
)
|
122
|
-
)
|
123
|
-
)
|
124
|
-
end
|
125
|
-
|
126
|
-
#
|
127
|
-
# 滅日を求める
|
128
|
-
#
|
129
|
-
# @param [Context::Context] context 暦コンテキスト
|
130
|
-
# @param [Cycle::AbstractRemainder] remainder 当日和暦日
|
131
|
-
# @param [Cycle::AbstractRemainder] average_remainder 経朔
|
132
|
-
#
|
133
|
-
# @return [Result::Data::Option::VanishedDate::Option] 滅日オプション値
|
134
|
-
#
|
135
|
-
def vanished_date(context:, remainder:, average_remainder:)
|
136
|
-
return Result::Data::Option::VanishedDate::Option.new if average_remainder.invalid?
|
137
|
-
|
138
|
-
location = Calculation::Option::VanishedDate::Location.new(
|
139
|
-
context: context, average_remainder: average_remainder
|
140
|
-
)
|
141
|
-
|
142
|
-
return Result::Data::Option::VanishedDate::Option.new if location.invalid?
|
143
|
-
|
144
|
-
unless location.exist?
|
145
|
-
# 結果確認のため経朔だけは設定する
|
146
|
-
return Result::Data::Option::VanishedDate::Option.new(
|
147
|
-
calculation: Result::Data::Option::VanishedDate::Calculation.new(
|
148
|
-
average_remainder: average_remainder
|
149
|
-
)
|
150
|
-
)
|
151
|
-
end
|
152
|
-
|
153
|
-
vanished_date = location.get
|
154
|
-
|
155
|
-
vanished_date_option(
|
156
|
-
matched: remainder.day == vanished_date.day, location: location
|
157
|
-
)
|
158
|
-
end
|
159
|
-
|
160
|
-
#
|
161
|
-
# 滅日オプション値を生成する
|
162
|
-
#
|
163
|
-
# @param [True, False] matched 滅日有無
|
164
|
-
# @param [Calculation::Option::VanishedDate::Location] location 滅日位置
|
165
|
-
#
|
166
|
-
# @return [Result::Data::Option::VanishedDate::Option] 滅日オプション値
|
167
|
-
#
|
168
|
-
def vanished_date_option(matched:, location:)
|
169
|
-
vanished_date = location.get
|
170
|
-
Result::Data::Option::VanishedDate::Option.new(
|
171
|
-
matched: matched,
|
172
|
-
calculation: Result::Data::Option::VanishedDate::Calculation.new(
|
173
|
-
remainder: vanished_date.format,
|
174
|
-
average_remainder: location.average_remainder
|
175
|
-
)
|
176
|
-
)
|
177
|
-
end
|
178
45
|
end
|
179
46
|
end
|
180
47
|
end
|
@@ -48,8 +48,8 @@ module Zakuro
|
|
48
48
|
)
|
49
49
|
|
50
50
|
list = create_list(
|
51
|
-
context: context,
|
52
|
-
operated_years: operated_years, years: years
|
51
|
+
context: context, range: range,
|
52
|
+
operated_years: operated_years, years: years
|
53
53
|
)
|
54
54
|
|
55
55
|
Result::Range.new(list: list)
|
@@ -82,14 +82,13 @@ module Zakuro
|
|
82
82
|
# 1日検索結果リストを生成する
|
83
83
|
#
|
84
84
|
# @param [Context::Context] context 暦コンテキスト
|
85
|
+
# @param [SpecifiedRange] range 特定範囲
|
85
86
|
# @param [Array<Base::OperatedYear>] operated_years 運用結果範囲
|
86
87
|
# @param [Array<Base::Year>] years 完全範囲
|
87
|
-
# @param [SpecifiedRange] range 特定範囲
|
88
88
|
#
|
89
89
|
# @return [Array<Result::Single>] 結果リスト
|
90
90
|
#
|
91
|
-
def create_list(context:, operated_years: [], years: []
|
92
|
-
range:)
|
91
|
+
def create_list(context:, range:, operated_years: [], years: [])
|
93
92
|
western_start_date = range.start_date.day.western_date
|
94
93
|
western_last_date = range.last_date.day.western_date
|
95
94
|
|
@@ -37,11 +37,11 @@ module Zakuro
|
|
37
37
|
|
38
38
|
# @return [Hash<String, String>] 関連
|
39
39
|
CLASSES = {
|
40
|
-
'remainder' => 'Zakuro::$VERSION::Cycle::Remainder',
|
41
|
-
'solar_term' => 'Zakuro::$VERSION::Cycle::SolarTerm',
|
42
|
-
'annual_range' => 'Zakuro::$VERSION::Range::AnnualRange',
|
43
|
-
'dropped_date_parameter' => 'Zakuro::$VERSION::Option::DroppedDate::Parameter',
|
44
|
-
'vanished_date_parameter' => 'Zakuro::$VERSION::Option::VanishedDate::Parameter'
|
40
|
+
'remainder' => 'Zakuro::Version::$VERSION::Cycle::Remainder',
|
41
|
+
'solar_term' => 'Zakuro::Version::$VERSION::Cycle::SolarTerm',
|
42
|
+
'annual_range' => 'Zakuro::Version::$VERSION::Range::AnnualRange',
|
43
|
+
'dropped_date_parameter' => 'Zakuro::Version::$VERSION::Option::DroppedDate::Parameter',
|
44
|
+
'vanished_date_parameter' => 'Zakuro::Version::$VERSION::Option::VanishedDate::Parameter'
|
45
45
|
}.freeze
|
46
46
|
|
47
47
|
#
|
@@ -1,6 +1,6 @@
|
|
1
1
|
# frozen_string_literal: true
|
2
2
|
|
3
|
-
require_relative '../../
|
3
|
+
require_relative '../../tool/typeconv'
|
4
4
|
|
5
5
|
# :nodoc:
|
6
6
|
module Zakuro
|
@@ -104,10 +104,10 @@ module Zakuro
|
|
104
104
|
|
105
105
|
Calendar.new(
|
106
106
|
gengou: matched[1],
|
107
|
-
year:
|
107
|
+
year: Tool::Typeconv.to_i(text: matched[2], default: INVALID),
|
108
108
|
leaped: matched[3] ? true : false,
|
109
|
-
month:
|
110
|
-
day:
|
109
|
+
month: Tool::Typeconv.to_i(text: matched[4], default: INVALID),
|
110
|
+
day: Tool::Typeconv.to_i(text: matched[5], default: INVALID)
|
111
111
|
)
|
112
112
|
end
|
113
113
|
|
@@ -85,7 +85,7 @@ module Zakuro
|
|
85
85
|
def connect(list: []) # rubocop:disable Metrics/MethodLength
|
86
86
|
result = []
|
87
87
|
list.each do |linear_gengou|
|
88
|
-
if result.
|
88
|
+
if result.empty?
|
89
89
|
result.push(linear_gengou)
|
90
90
|
next
|
91
91
|
end
|
@@ -145,7 +145,7 @@ module Zakuro
|
|
145
145
|
)
|
146
146
|
end
|
147
147
|
|
148
|
-
def shave_gengou(this:, other:)
|
148
|
+
def shave_gengou(this:, other:)
|
149
149
|
start = this.start_date
|
150
150
|
last = this.last_date
|
151
151
|
|
@@ -2,7 +2,7 @@
|
|
2
2
|
|
3
3
|
require_relative '../../../western/calendar'
|
4
4
|
|
5
|
-
require_relative '
|
5
|
+
require_relative '../../type/base/gengou_set'
|
6
6
|
|
7
7
|
# :nodoc:
|
8
8
|
module Zakuro
|
@@ -33,7 +33,7 @@ module Zakuro
|
|
33
33
|
# @param [Resource::Gengou] gengou 元号
|
34
34
|
#
|
35
35
|
def initialize(start_date: Western::Calendar.new, last_date: Western::Calendar.new,
|
36
|
-
gengou:
|
36
|
+
gengou: Type::Base::Gengou.new)
|
37
37
|
@gengou = gengou
|
38
38
|
@start_date = start_date.invalid? ? native_start_date : start_date
|
39
39
|
@last_date = last_date.invalid? ? native_last_date : last_date
|
@@ -42,7 +42,9 @@ module Zakuro
|
|
42
42
|
start_date: Western::Calendar.new, last_date: Western::Calendar.new,
|
43
43
|
operated: false, restored: false)
|
44
44
|
if operated
|
45
|
-
result = OPERATED_SUMMARY.get(
|
45
|
+
result = OPERATED_SUMMARY.get(
|
46
|
+
line: line, start_date: start_date, last_date: last_date
|
47
|
+
)
|
46
48
|
return result unless restored
|
47
49
|
|
48
50
|
return restore(line: line, list: result)
|
@@ -54,14 +56,14 @@ module Zakuro
|
|
54
56
|
#
|
55
57
|
# 指定した範囲内の元号を取得する(元号名)
|
56
58
|
#
|
57
|
-
# @param [Integer] line 行
|
58
59
|
# @param [String] name 元号名
|
60
|
+
# @param [Integer] line 行
|
59
61
|
# @param [True, False] operated 運用値設定
|
60
62
|
# @param [True, False] restored 運用値から計算値に戻すか
|
61
63
|
#
|
62
64
|
# @return [Array<LinearGengou>] 元号
|
63
65
|
#
|
64
|
-
def get_by_name(line: FIRST_LINE,
|
66
|
+
def get_by_name(name:, line: FIRST_LINE, operated: false, restored: false)
|
65
67
|
if operated
|
66
68
|
result = OPERATED_SUMMARY.get_by_name(line: line, name: name)
|
67
69
|
return result unless restored
|
@@ -1,7 +1,7 @@
|
|
1
1
|
# frozen_string_literal: true
|
2
2
|
|
3
3
|
require_relative '../../../western/calendar'
|
4
|
-
require_relative '
|
4
|
+
require_relative '../../type/base/gengou_set'
|
5
5
|
require_relative './validator'
|
6
6
|
require 'yaml'
|
7
7
|
|
@@ -41,6 +41,7 @@ module Zakuro
|
|
41
41
|
#
|
42
42
|
# @param [Hash<String, Strin>] hash 元号情報
|
43
43
|
# @param [Integer] index (元号セット内での)元号の要素位置
|
44
|
+
# @param [True, False] operated 運用値設定
|
44
45
|
#
|
45
46
|
def initialize(hash:, index:, operated: false)
|
46
47
|
@index = index
|
@@ -53,21 +54,21 @@ module Zakuro
|
|
53
54
|
#
|
54
55
|
# 元号情報を生成する
|
55
56
|
#
|
56
|
-
# @return [Gengou] 元号情報
|
57
|
+
# @return [Type::Base::Gengou] 元号情報
|
57
58
|
#
|
58
59
|
def create
|
59
60
|
year = Both::YearParser.new(hash: start_year).create
|
60
61
|
date = SwitchDateParser.new(hash: start_date, operated: operated).create
|
61
62
|
|
62
|
-
Gengou.new(name: name, start_year: year,
|
63
|
-
|
63
|
+
Type::Base::Gengou.new(name: name, start_year: year,
|
64
|
+
start_date: date)
|
64
65
|
end
|
65
66
|
end
|
66
67
|
|
67
68
|
#
|
68
|
-
#
|
69
|
+
# GengouSetParser 元号セット情報の検証/展開
|
69
70
|
#
|
70
|
-
class
|
71
|
+
class GengouSetParser
|
71
72
|
# @return [String] 元号セットID
|
72
73
|
attr_reader :id
|
73
74
|
# @return [String] 元号セット名
|
@@ -99,12 +100,12 @@ module Zakuro
|
|
99
100
|
#
|
100
101
|
# 元号セット情報を生成する
|
101
102
|
#
|
102
|
-
# @return [
|
103
|
+
# @return [Type::Base::GengouSet] 元号セット情報
|
103
104
|
#
|
104
105
|
def create
|
105
106
|
date = SwitchDateParser.new(hash: last_date, operated: operated).create
|
106
107
|
list = create_list
|
107
|
-
|
108
|
+
Type::Base::GengouSet.new(
|
108
109
|
id: id, name: name, last_date: date, list: list
|
109
110
|
)
|
110
111
|
end
|
@@ -114,7 +115,7 @@ module Zakuro
|
|
114
115
|
#
|
115
116
|
# 元号情報を生成する
|
116
117
|
#
|
117
|
-
# @return [Array<Gengou>] 元号情報
|
118
|
+
# @return [Array<Type::Base::Gengou>] 元号情報
|
118
119
|
#
|
119
120
|
def create_list
|
120
121
|
result = []
|
@@ -200,13 +201,13 @@ module Zakuro
|
|
200
201
|
#
|
201
202
|
# 切替日(運用/計算)情報を生成する
|
202
203
|
#
|
203
|
-
# @return [SwitchDate] 切替日(運用/計算)情報
|
204
|
+
# @return [Type::Base::SwitchDate] 切替日(運用/計算)情報
|
204
205
|
#
|
205
206
|
def create
|
206
207
|
calculation_date = Both::DateParser.new(hash: calculation).create
|
207
208
|
operation_date = Both::DateParser.new(hash: operation).create
|
208
209
|
|
209
|
-
|
210
|
+
Type::Base::SwitchDate.new(
|
210
211
|
calculation: calculation_date, operation: operation_date,
|
211
212
|
operated: operated
|
212
213
|
)
|
@@ -245,7 +246,7 @@ module Zakuro
|
|
245
246
|
japan_year = japan.to_i
|
246
247
|
western_year = western.to_i
|
247
248
|
|
248
|
-
|
249
|
+
Type::Base::Both::Year.new(
|
249
250
|
japan: japan_year, western: western_year
|
250
251
|
)
|
251
252
|
end
|
@@ -273,7 +274,7 @@ module Zakuro
|
|
273
274
|
#
|
274
275
|
# 日情報を生成する
|
275
276
|
#
|
276
|
-
# @return [Both::Date] 日情報
|
277
|
+
# @return [Type::Base::Both::Date] 日情報
|
277
278
|
#
|
278
279
|
def create
|
279
280
|
japan_date = Japan::Calendar.new
|
@@ -282,7 +283,7 @@ module Zakuro
|
|
282
283
|
japan_date = Japan::Calendar.parse(text: japan) unless japan == ''
|
283
284
|
western_date = Western::Calendar.parse(text: western) unless western == ''
|
284
285
|
|
285
|
-
|
286
|
+
Type::Base::Both::Date.new(
|
286
287
|
japan: japan_date, western: western_date
|
287
288
|
)
|
288
289
|
end
|
@@ -296,7 +297,7 @@ module Zakuro
|
|
296
297
|
# @param [String] filepath 元号セットファイルパス
|
297
298
|
# @param [True, False] operated 運用値設定
|
298
299
|
#
|
299
|
-
# @return [
|
300
|
+
# @return [Type::Base::GengouSet] 元号セット情報
|
300
301
|
#
|
301
302
|
# @raise [ArgumentError] 引数エラー
|
302
303
|
#
|
@@ -307,7 +308,7 @@ module Zakuro
|
|
307
308
|
|
308
309
|
raise ArgumentError, failed.join("\n") unless failed.empty?
|
309
310
|
|
310
|
-
parser =
|
311
|
+
parser = GengouSetParser.new(hash: yaml, operated: operated)
|
311
312
|
parser.create
|
312
313
|
end
|
313
314
|
end
|