zakuro 0.6.0 → 0.7.2

Sign up to get free protection for your applications and to get access to all the features.
Files changed (142) hide show
  1. checksums.yaml +4 -4
  2. data/Makefile +3 -0
  3. data/README.md +58 -16
  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 +50 -4
  10. data/lib/zakuro/calculation/base/linear_gengou.rb +6 -6
  11. data/lib/zakuro/calculation/base/operated_year.rb +3 -3
  12. data/lib/zakuro/calculation/base/year.rb +4 -4
  13. data/lib/zakuro/calculation/cycle/abstract_remainder.rb +5 -3
  14. data/lib/zakuro/calculation/era/gengou/abstract_scroll.rb +209 -0
  15. data/lib/zakuro/calculation/era/gengou/dated_scroll.rb +30 -0
  16. data/lib/zakuro/calculation/era/gengou/internal/connector.rb +107 -0
  17. data/lib/zakuro/calculation/era/gengou/internal/counter.rb +214 -0
  18. data/lib/zakuro/calculation/era/gengou/internal/publisher.rb +104 -0
  19. data/lib/zakuro/calculation/era/gengou/internal/reserve/abstract_list.rb +230 -0
  20. data/lib/zakuro/calculation/era/gengou/internal/reserve/abstract_range.rb +193 -0
  21. data/lib/zakuro/calculation/era/gengou/internal/reserve/dated_list.rb +48 -0
  22. data/lib/zakuro/calculation/era/gengou/internal/reserve/dated_range.rb +30 -0
  23. data/lib/zakuro/calculation/era/gengou/internal/reserve/empty_link.rb +158 -0
  24. data/lib/zakuro/calculation/era/gengou/internal/reserve/named_list.rb +125 -0
  25. data/lib/zakuro/calculation/era/gengou/internal/reserve/named_range.rb +75 -0
  26. data/lib/zakuro/calculation/{gengou → era/gengou}/internal/reserve.rb +6 -7
  27. data/lib/zakuro/calculation/era/gengou/named_scroll.rb +30 -0
  28. data/lib/zakuro/calculation/{version → era/version}/internal/crawler.rb +7 -7
  29. data/lib/zakuro/calculation/{version → era/version}/internal/range.rb +4 -4
  30. data/lib/zakuro/calculation/{version → era/version}/version.rb +3 -3
  31. data/lib/zakuro/calculation/monthly/initialized_month.rb +1 -1
  32. data/lib/zakuro/calculation/monthly/month.rb +44 -5
  33. data/lib/zakuro/calculation/monthly/operated_month.rb +2 -2
  34. data/lib/zakuro/calculation/option/dropped_date/abstract_parameter.rb +44 -0
  35. data/lib/zakuro/calculation/option/dropped_date/location.rb +135 -0
  36. data/lib/zakuro/calculation/range/{full_range.rb → abstract_full_range.rb} +29 -27
  37. data/lib/zakuro/calculation/range/{operated_range.rb → abstract_operation_range.rb} +11 -14
  38. data/lib/zakuro/calculation/range/dated_full_range.rb +32 -0
  39. data/lib/zakuro/calculation/range/dated_operation_range.rb +33 -0
  40. data/lib/zakuro/calculation/range/medieval_annual_range.rb +2 -2
  41. data/lib/zakuro/calculation/range/named_full_range.rb +38 -0
  42. data/lib/zakuro/calculation/range/named_operation_range.rb +36 -0
  43. data/lib/zakuro/calculation/range/operated_solar_terms.rb +9 -11
  44. data/lib/zakuro/calculation/range/transfer/year_boundary.rb +6 -6
  45. data/lib/zakuro/calculation/stella/solar/abstract_location.rb +2 -0
  46. data/lib/zakuro/calculation/summary/internal/day.rb +40 -0
  47. data/lib/zakuro/calculation/summary/internal/month.rb +92 -0
  48. data/lib/zakuro/calculation/summary/{single.rb → internal/operation.rb} +6 -40
  49. data/lib/zakuro/calculation/summary/internal/option.rb +85 -0
  50. data/lib/zakuro/calculation/summary/japan/range.rb +158 -0
  51. data/lib/zakuro/calculation/summary/japan/single.rb +118 -0
  52. data/lib/zakuro/calculation/summary/japan/specifier/single_day.rb +96 -0
  53. data/lib/zakuro/calculation/summary/western/range.rb +124 -0
  54. data/lib/zakuro/calculation/summary/western/single.rb +113 -0
  55. data/lib/zakuro/calculation/summary/western/specifier/multiple_day.rb +174 -0
  56. data/lib/zakuro/calculation/summary/western/specifier/single_day.rb +98 -0
  57. data/lib/zakuro/calculation/type/optional.rb +46 -0
  58. data/lib/zakuro/condition.rb +75 -22
  59. data/lib/zakuro/context/context.rb +44 -0
  60. data/lib/zakuro/context/option.rb +117 -0
  61. data/lib/zakuro/context/version_class_resolver.rb +110 -0
  62. data/lib/zakuro/era/japan/gengou/alignment/aligner.rb +125 -0
  63. data/lib/zakuro/era/japan/gengou/alignment/division.rb +168 -0
  64. data/lib/zakuro/era/japan/gengou/alignment/line.rb +175 -0
  65. data/lib/zakuro/era/japan/gengou/alignment/linear_gengou.rb +187 -0
  66. data/lib/zakuro/era/japan/gengou/alignment.rb +55 -0
  67. data/lib/zakuro/era/japan/gengou/resource/parser.rb +245 -0
  68. data/lib/zakuro/era/japan/gengou/resource/type.rb +299 -0
  69. data/lib/zakuro/era/japan/gengou/resource/validator.rb +347 -0
  70. data/lib/zakuro/era/japan/gengou/{yaml → resource/yaml}/set-001-until-south.yaml +2 -2
  71. data/lib/zakuro/era/japan/gengou/{yaml → resource/yaml}/set-002-from-north.yaml +2 -2
  72. data/lib/zakuro/era/japan/gengou/{yaml → resource/yaml}/set-003-modern.yaml +2 -2
  73. data/lib/zakuro/era/japan/gengou/resource.rb +33 -0
  74. data/lib/zakuro/era/japan/gengou.rb +25 -79
  75. data/lib/zakuro/era/japan/version.rb +18 -18
  76. data/lib/zakuro/era/western/calendar.rb +13 -9
  77. data/lib/zakuro/exception/case/pattern.rb +71 -0
  78. data/lib/zakuro/exception/case/preset.rb +51 -0
  79. data/lib/zakuro/exception/case/template.rb +48 -0
  80. data/lib/zakuro/exception/cause.rb +28 -0
  81. data/lib/zakuro/exception/exception.rb +37 -0
  82. data/lib/zakuro/exception/zakuro_error.rb +46 -0
  83. data/lib/zakuro/gateway/locale/date.rb +127 -0
  84. data/lib/zakuro/gateway/locale/range.rb +67 -0
  85. data/lib/zakuro/gateway/range.rb +99 -0
  86. data/lib/zakuro/gateway/single.rb +70 -0
  87. data/lib/zakuro/merchant.rb +84 -12
  88. data/lib/zakuro/operation/month/parser.rb +11 -9
  89. data/lib/zakuro/operation/month/type.rb +31 -31
  90. data/lib/zakuro/operation/month/validator.rb +50 -50
  91. data/lib/zakuro/operation/yaml/month.yaml +3736 -3736
  92. data/lib/zakuro/output/logger.rb +17 -3
  93. data/lib/zakuro/output/response.rb +24 -57
  94. data/lib/zakuro/result/data/day.rb +43 -0
  95. data/lib/zakuro/result/data/gengou.rb +35 -0
  96. data/lib/zakuro/result/data/month.rb +63 -0
  97. data/lib/zakuro/result/data/option/abstract_option.rb +37 -0
  98. data/lib/zakuro/result/data/option/dropped_date/calculation.rb +47 -0
  99. data/lib/zakuro/result/data/option/dropped_date/option.rb +47 -0
  100. data/lib/zakuro/result/data/option/dropped_date/solar_term.rb +48 -0
  101. data/lib/zakuro/result/data/single_day.rb +56 -0
  102. data/lib/zakuro/result/data/solar_term.rb +35 -0
  103. data/lib/zakuro/result/data/year.rb +45 -0
  104. data/lib/zakuro/result/operation/bundle.rb +44 -0
  105. data/lib/zakuro/result/operation/month/annotation.rb +40 -0
  106. data/lib/zakuro/result/operation/month/bundle.rb +36 -0
  107. data/lib/zakuro/result/operation/month/history.rb +54 -0
  108. data/lib/zakuro/result/result.rb +21 -2
  109. data/lib/zakuro/tools/stringifier.rb +26 -3
  110. data/lib/zakuro/version/daien/cycle/remainder.rb +2 -2
  111. data/lib/zakuro/version/daien/option/dropped_date/parameter.rb +31 -0
  112. data/lib/zakuro/version/daien/range/annual_range.rb +1 -1
  113. data/lib/zakuro/version/daien/stella/lunar/adjustment.rb +2 -0
  114. data/lib/zakuro/version/daien/stella/lunar/value.rb +2 -0
  115. data/lib/zakuro/version/genka/cycle/remainder.rb +2 -2
  116. data/lib/zakuro/version/genka/option/dropped_date/parameter.rb +31 -0
  117. data/lib/zakuro/version/genka/range/annual_range.rb +1 -1
  118. data/lib/zakuro/version/gihou/cycle/remainder.rb +2 -2
  119. data/lib/zakuro/version/gihou/option/dropped_date/parameter.rb +31 -0
  120. data/lib/zakuro/version/gihou/range/annual_range.rb +1 -1
  121. data/lib/zakuro/version/gihou/stella/lunar/adjustment.rb +2 -0
  122. data/lib/zakuro/version/gihou/stella/lunar/value.rb +2 -0
  123. data/lib/zakuro/version/senmyou/README.md +11 -7
  124. data/lib/zakuro/version/senmyou/const/remainder.rb +5 -0
  125. data/lib/zakuro/version/senmyou/cycle/remainder.rb +37 -2
  126. data/lib/zakuro/version/senmyou/option/dropped_date/parameter.rb +33 -0
  127. data/lib/zakuro/version/senmyou/range/annual_range.rb +1 -1
  128. data/lib/zakuro/version/senmyou/stella/lunar/adjustment.rb +2 -0
  129. data/lib/zakuro/version/senmyou/stella/lunar/value.rb +2 -0
  130. metadata +85 -24
  131. data/lib/zakuro/calculation/gengou/internal/counter.rb +0 -129
  132. data/lib/zakuro/calculation/gengou/internal/reserve/interval.rb +0 -183
  133. data/lib/zakuro/calculation/gengou/internal/reserve/list.rb +0 -382
  134. data/lib/zakuro/calculation/gengou/scroll.rb +0 -262
  135. data/lib/zakuro/calculation/specifier/single_day.rb +0 -87
  136. data/lib/zakuro/era/japan/gengou/parser.rb +0 -237
  137. data/lib/zakuro/era/japan/gengou/type.rb +0 -285
  138. data/lib/zakuro/era/japan/gengou/validator.rb +0 -341
  139. data/lib/zakuro/result/data.rb +0 -187
  140. data/lib/zakuro/result/operation.rb +0 -114
  141. data/lib/zakuro/version/context.rb +0 -44
  142. data/lib/zakuro/version/version_class_resolver.rb +0 -74
@@ -0,0 +1,209 @@
1
+ # frozen_string_literal: true
2
+
3
+ require_relative '../../../era/western/calendar'
4
+ require_relative '../../base/gengou'
5
+ require_relative '../../base/linear_gengou'
6
+ require_relative './internal/connector'
7
+ require_relative './internal/publisher'
8
+
9
+ # :nodoc:
10
+ module Zakuro
11
+ # :nodoc:
12
+ module Calculation
13
+ # :nodoc:
14
+ module Gengou
15
+ # AbstractScroll
16
+ #
17
+ # 元号スクロール
18
+ #
19
+ class AbstractScroll
20
+ # @return [Western::Calendar] 月初日
21
+ attr_reader :monthly_start_date
22
+ # @return [Western::Calendar] 月末日
23
+ attr_reader :monthly_last_date
24
+ # @return [Reserve::AbstractRange] 予約範囲
25
+ attr_reader :range
26
+ # @return [Array<Counte>] 1行目元号
27
+ attr_reader :first_gengou
28
+ # @return [Array<Counte>] 2行目元号
29
+ attr_reader :second_gengou
30
+ # @return [Connector] 行変更済元号
31
+ attr_reader :connector
32
+
33
+ #
34
+ # 初期化
35
+ #
36
+ # @param [Reserve::AbstractRange] range 予約範囲
37
+ #
38
+ def initialize(range:)
39
+ @monthly_start_date = Western::Calendar.new
40
+ @monthly_last_date = Western::Calendar.new
41
+ @range = range
42
+ @first_gengou = []
43
+ @second_gengou = []
44
+ @ignited = false
45
+ @connector = Connector.new
46
+ end
47
+
48
+ #
49
+ # 進める
50
+ #
51
+ # @param [Monthly::Month] month 月
52
+ #
53
+ def run(month:)
54
+ unless @ignited
55
+ # 開始日の検索を行う
56
+ @ignited = ignite(month: month)
57
+ return
58
+ end
59
+
60
+ # 時間を進める
61
+ advance(month: month)
62
+ end
63
+
64
+ #
65
+ # 元号開始を試みる
66
+ #
67
+ # @param [Monthly::Month] month 月
68
+ #
69
+ # @return [True] 開始あり
70
+ # @return [False] 開始なし
71
+ #
72
+ def ignite(month:)
73
+ return false unless ignitable?(month: month)
74
+
75
+ japan_start_date = @range.japan_start_date
76
+
77
+ western_start_date = @range.western_start_date
78
+
79
+ # 今月初日(和暦日が1月2日であれば、開始日の1日前が初日)
80
+ @monthly_start_date = western_start_date.clone - japan_start_date.day + 1
81
+
82
+ # 今月末
83
+ @monthly_last_date = @monthly_start_date.clone + month.days - 1
84
+
85
+ update_current_gengou
86
+
87
+ true
88
+ end
89
+
90
+ #
91
+ # 進める
92
+ #
93
+ # @param [Monthly::Month] month 月
94
+ #
95
+ def advance(month:)
96
+ @monthly_start_date = @monthly_last_date.clone + 1
97
+
98
+ @monthly_last_date = @monthly_start_date.clone + month.days - 1
99
+
100
+ next_year if month.number == 1 && !month.leaped?
101
+
102
+ update_current_gengou
103
+ end
104
+
105
+ #
106
+ # 共通の元号に変換する
107
+ #
108
+ # @return [Base::Gengou] 元号
109
+ #
110
+ def to_gengou
111
+ start_date = @monthly_start_date.clone
112
+ last_date = @monthly_last_date.clone
113
+
114
+ # 行を超えた元号切り替え処理
115
+ continue_year
116
+
117
+ Publisher.run(
118
+ start_date: start_date, last_date: last_date,
119
+ first_gengou: @first_gengou, second_gengou: @second_gengou
120
+ )
121
+ end
122
+
123
+ #
124
+ # 開始西暦年を取得する
125
+ #
126
+ # @return [Integer] 開始西暦年
127
+ #
128
+ def western_start_year
129
+ @range.western_start_year
130
+ end
131
+
132
+ #
133
+ # 終了西暦年を取得する
134
+ #
135
+ # @return [Integer] 終了西暦年
136
+ #
137
+ def western_last_year
138
+ @range.western_last_year
139
+ end
140
+
141
+ private
142
+
143
+ #
144
+ # 行を跨ぐ元号年を継続させる
145
+ #
146
+ def continue_year
147
+ @connector.update(lines: [@first_gengou, @second_gengou])
148
+ end
149
+
150
+ #
151
+ # 現在月に合わせて元号を更新する
152
+ #
153
+ def update_current_gengou
154
+ start_date = @monthly_start_date
155
+ last_date = @monthly_last_date
156
+ first_gengou = @range.collect_first(start_date: start_date, last_date: last_date)
157
+ second_gengou = @range.collect_second(start_date: start_date,
158
+ last_date: last_date)
159
+
160
+ @first_gengou = replace_gengou(source: @first_gengou, destination: first_gengou)
161
+ @second_gengou = replace_gengou(source: @second_gengou, destination: second_gengou)
162
+ end
163
+
164
+ #
165
+ # 元号を差し替える
166
+ #
167
+ # @param [Array<Counter>] source 元の元号
168
+ # @param [Array<Counter>] destination 次の元号
169
+ #
170
+ # @return [Array<Counter>] 差し替え結果
171
+ #
172
+ def replace_gengou(source: [], destination: [])
173
+ return destination if destination.size.zero?
174
+
175
+ return destination if source.size.zero?
176
+
177
+ last = source[-1]
178
+ destination[0] = last if destination[0].name == last.name
179
+
180
+ destination
181
+ end
182
+
183
+ #
184
+ # 開始可能か
185
+ #
186
+ # @param [Monthly::Month] month 月
187
+ #
188
+ # @return [True] 開始可
189
+ # @return [True] 開始不可
190
+ #
191
+ def ignitable?(month:)
192
+ return false unless @monthly_start_date.invalid?
193
+
194
+ japan_start_date = @range.japan_start_date
195
+
196
+ japan_start_date.same_month?(leaped: month.leaped?, month: month.number)
197
+ end
198
+
199
+ #
200
+ # 次年にする
201
+ #
202
+ def next_year
203
+ @first_gengou.each(&:next_year)
204
+ @second_gengou.each(&:next_year)
205
+ end
206
+ end
207
+ end
208
+ end
209
+ end
@@ -0,0 +1,30 @@
1
+ # frozen_string_literal: true
2
+
3
+ require_relative './abstract_scroll'
4
+ require_relative './internal/reserve/dated_range'
5
+
6
+ # :nodoc:
7
+ module Zakuro
8
+ # :nodoc:
9
+ module Calculation
10
+ # :nodoc:
11
+ module Gengou
12
+ # DatedScroll
13
+ #
14
+ # 元号スクロール
15
+ #
16
+ class DatedScroll < AbstractScroll
17
+ #
18
+ # 初期化
19
+ #
20
+ # @param [Western::Calendar] start_date 西暦開始日(最大範囲)
21
+ # @param [Western::Calendar] last_date 西暦終了日(最大範囲)
22
+ #
23
+ def initialize(start_date: Western::Calendar.new, last_date: Western::Calendar.new)
24
+ range = Reserve::DatedRange.new(start_date: start_date, last_date: last_date)
25
+ super(range: range)
26
+ end
27
+ end
28
+ end
29
+ end
30
+ end
@@ -0,0 +1,107 @@
1
+ # frozen_string_literal: true
2
+
3
+ require_relative '../../../../era/japan/gengou/resource'
4
+ require_relative '../../../../era/japan/calendar'
5
+ require_relative '../../../../era/western/calendar'
6
+
7
+ # :nodoc:
8
+ module Zakuro
9
+ # :nodoc:
10
+ module Calculation
11
+ # :nodoc:
12
+ module Gengou
13
+ #
14
+ # Connector 元号接続器
15
+ #
16
+ # 現在は"明徳"のみを解決している
17
+ # 元中1年4月28日 元中9年閏10月4日 明徳5年7月4日
18
+ # 1384-05-18 1392-11-18 1394-8-1
19
+ # [1] |-------------元中---------------|---------明徳------------|
20
+ # [2] |---------明徳--------|
21
+ # 明徳1年3月26日
22
+ # 1390-04-12
23
+ #
24
+ # * 明徳は2行目元号から始まる
25
+ # * 1392-11-19より1行目元号に移行する
26
+ # * 移行のタイミングで元号年を引き継げるようにする
27
+ #
28
+ class Connector
29
+ # @return [Array<Counter>] 未解決元号
30
+ attr_reader :unsolved_list
31
+
32
+ #
33
+ # 初期化
34
+ #
35
+ def initialize
36
+ @unsolved_list = []
37
+ end
38
+
39
+ #
40
+ # 元号を更新する
41
+ #
42
+ # @param [Array<Array<Counter>>] lines 全行元号
43
+ #
44
+ def update(lines: [])
45
+ lines.each do |line|
46
+ line.each_with_index do |gengou, index|
47
+ next unless gengou.changed?
48
+
49
+ line[index] = replace(gengou: gengou)
50
+ end
51
+ end
52
+ end
53
+
54
+ #
55
+ # 元号を年を更新した元号に入れ替える
56
+ #
57
+ # @param [Counter] gengou 元号
58
+ #
59
+ # @return [Counter] 元号/更新済元号
60
+ #
61
+ def replace(gengou:)
62
+ matched_index = -1
63
+ @unsolved_list.each_with_index do |unsolved, index|
64
+ next unless unsolved.name == gengou.name
65
+
66
+ matched_index = index
67
+ break
68
+ end
69
+
70
+ if matched_index == -1
71
+ @unsolved_list.push(gengou)
72
+ return gengou
73
+ end
74
+
75
+ matched = @unsolved_list[matched_index]
76
+
77
+ result = recreate(gengou: gengou, unsolved: matched)
78
+
79
+ @unsolved_list[matched_index] = result
80
+
81
+ # 分離した元号の末尾まで到達した
82
+ @unsolved_list.delete_at(matched_index) unless result.change_last_date?
83
+
84
+ result
85
+ end
86
+
87
+ #
88
+ # 年を更新した元号を生成する
89
+ #
90
+ # @param [Counter] gengou 元号
91
+ # @param [Counter] unsolved 未解決元号
92
+ #
93
+ # @return [Counter] 更新済元号
94
+ #
95
+ def recreate(gengou:, unsolved:)
96
+ japan_year = gengou.japan_year
97
+ japan_year = unsolved.japan_year if unsolved.japan_year > gengou.japan_year
98
+
99
+ Counter.new(
100
+ gengou: gengou.gengou, start_date: gengou.start_date,
101
+ last_date: gengou.last_date, japan_year: japan_year
102
+ )
103
+ end
104
+ end
105
+ end
106
+ end
107
+ end
@@ -0,0 +1,214 @@
1
+ # frozen_string_literal: true
2
+
3
+ require_relative '../../../../era/japan/gengou/resource'
4
+ require_relative '../../../../era/japan/calendar'
5
+ require_relative '../../../../era/western/calendar'
6
+
7
+ # :nodoc:
8
+ module Zakuro
9
+ # :nodoc:
10
+ module Calculation
11
+ # :nodoc:
12
+ module Gengou
13
+ #
14
+ # Counter 加算元号
15
+ #
16
+ class Counter
17
+ # @return [Integer] 不正値
18
+ INVALID_YEAR = -1
19
+
20
+ # @return [Japan::Resource::Gengou] 元号
21
+ attr_reader :gengou
22
+ # @return [Integer] 元号年
23
+ attr_reader :japan_year
24
+ # @return [Integer] 西暦年
25
+ attr_reader :western_year
26
+ # @return [Western::Calendar] 西暦開始年
27
+ attr_reader :start_date
28
+ # @return [Western::Calendar] 西暦終了年
29
+ attr_reader :last_date
30
+
31
+ #
32
+ # 初期化
33
+ #
34
+ # @param [Japan::Resource::Gengou] gengou 元号
35
+ # @param [Western::Calendar] start_date 西暦開始年
36
+ # @param [Western::Calendar] last_date 西暦終了年
37
+ # @param [Integer] japan_year 和暦年
38
+ #
39
+ def initialize(gengou: Japan::Resource::Gengou.new,
40
+ start_date: Western::Calendar.new, last_date: Western::Calendar.new,
41
+ japan_year: INVALID_YEAR)
42
+ @gengou = gengou
43
+ @japan_year = japan_year
44
+ @japan_year = gengou.both_start_year.japan if @japan_year == INVALID_YEAR
45
+ @western_year = gengou.both_start_year.western
46
+
47
+ @start_date = start_date.clone
48
+ @last_date = last_date.clone
49
+
50
+ select_valid_date
51
+ end
52
+
53
+ #
54
+ # 和暦開始日を取得する
55
+ #
56
+ # @return [Japan::Calendar] 和暦開始日
57
+ #
58
+ def japan_start_date
59
+ return Japan::Calendar.new if @gengou.invalid?
60
+
61
+ @gengou.both_start_date.japan
62
+ end
63
+
64
+ #
65
+ # 西暦開始日を取得する
66
+ #
67
+ # @return [Western::Calendar] 西暦開始日
68
+ #
69
+ def western_start_date
70
+ return Western::Calendar.new if @gengou.invalid?
71
+
72
+ @start_date
73
+ end
74
+
75
+ #
76
+ # 西暦終了日を取得する
77
+ #
78
+ # @return [Western::Calendar] 西暦終了日
79
+ #
80
+ def western_last_date
81
+ return Western::Calendar.new if @gengou.invalid?
82
+
83
+ @last_date
84
+ end
85
+
86
+ #
87
+ # 次年にする
88
+ #
89
+ # @return [MultiGengou] 自身
90
+ #
91
+ def next_year
92
+ @japan_year += 1
93
+ @western_year += 1
94
+
95
+ self
96
+ end
97
+
98
+ #
99
+ # 元号名を取得する
100
+ #
101
+ # @return [String] 元号名
102
+ #
103
+ def name
104
+ return '' unless @gengou
105
+
106
+ @gengou.name
107
+ end
108
+
109
+ #
110
+ # 不正か
111
+ #
112
+ # @return [True] 不正
113
+ # @return [False] 不正なし
114
+ #
115
+ def invalid?
116
+ @gengou.invalid? || @japan_year == INVALID_YEAR || @western_year == INVALID_YEAR
117
+ end
118
+
119
+ #
120
+ # 指定した日が元号に含まれるか
121
+ #
122
+ # @param [Western::Calendar] date 日
123
+ #
124
+ # @return [True] 含まれる
125
+ # @return [False] 含まれない
126
+ #
127
+ def include?
128
+ @gengou.include?
129
+ end
130
+
131
+ #
132
+ # 元は1繋ぎであった元号が別の行に存在するか(設定値から変更されているか)?
133
+ #
134
+ # @return [True] 存在する
135
+ # @return [False] 存在しない
136
+ #
137
+ def changed?
138
+ return true if change_start_date?
139
+
140
+ return true if change_last_date?
141
+
142
+ false
143
+ end
144
+
145
+ #
146
+ # 開始日が設定された開始日と異なるか(行が変更されているか)
147
+ #
148
+ # @return [True] 異なる
149
+ # @return [False] 同一
150
+ #
151
+ def change_start_date?
152
+ return false if invalid?
153
+
154
+ @start_date != native_start_date
155
+ end
156
+
157
+ #
158
+ # 終了日が設定された終了日と異なるか(行が変更されているか)
159
+ #
160
+ # @return [True] 異なる
161
+ # @return [False] 同一
162
+ #
163
+ def change_last_date?
164
+ return false if invalid?
165
+
166
+ @last_date != native_last_date
167
+ end
168
+
169
+ #
170
+ # ディープコピー
171
+ #
172
+ # @param [MultiGengou] obj 自身
173
+ #
174
+ def initialize_copy(obj)
175
+ @gengou = obj.gengou.clone
176
+ @japan_year = obj.japan_year
177
+ @western_year = obj.western_year
178
+ @start_date = obj.start_date.clone
179
+ @last_date = obj.last_date.clone
180
+ end
181
+
182
+ private
183
+
184
+ #
185
+ # 有効な日付範囲を選択する
186
+ #
187
+ def select_valid_date
188
+ return if @gengou.invalid?
189
+
190
+ @start_date = @gengou.both_start_date.western.clone if @start_date.invalid?
191
+ @last_date = @gengou.last_date.clone if @last_date.invalid?
192
+ end
193
+
194
+ #
195
+ # 設定された元号の開始日を取得する
196
+ #
197
+ # @return [Western::Calendar]設定された元号の開始日
198
+ #
199
+ def native_start_date
200
+ @gengou.both_start_date.western
201
+ end
202
+
203
+ #
204
+ # 設定された元号の終了日を取得する
205
+ #
206
+ # @return [Western::Calendar] 設定された元号の終了日
207
+ #
208
+ def native_last_date
209
+ @gengou.last_date
210
+ end
211
+ end
212
+ end
213
+ end
214
+ end
@@ -0,0 +1,104 @@
1
+ # frozen_string_literal: true
2
+
3
+ require_relative '../../../../era/western/calendar'
4
+ require_relative '../../../base/linear_gengou'
5
+
6
+ # :nodoc:
7
+ module Zakuro
8
+ # :nodoc:
9
+ module Calculation
10
+ # :nodoc:
11
+ module Gengou
12
+ # Publisher
13
+ #
14
+ # 元号発行
15
+ #
16
+ module Publisher
17
+ #
18
+ # 発行する
19
+ #
20
+ # @param [Western::Calendar] start_date 西暦開始日
21
+ # @param [Western::Calendar] last_date 西暦終了日
22
+ # @param [Array<Counter>] first_gengou 1行目元号
23
+ # @param [Array<Counter>] second_gengou 2行目元号
24
+ #
25
+ # @return [Base::Gengou] 元号
26
+ #
27
+ def self.run(start_date: Western::Calendar.new, last_date: Western::Calendar.new,
28
+ first_gengou: [], second_gengou: [])
29
+
30
+ Base::Gengou.new(
31
+ start_date: start_date,
32
+ last_date: last_date,
33
+ first_line: to_linear_gengou(
34
+ start_date: start_date, last_date: last_date, gengou_list: first_gengou
35
+ ),
36
+ second_line: to_linear_gengou(
37
+ start_date: start_date, last_date: last_date, gengou_list: second_gengou
38
+ )
39
+ )
40
+ end
41
+
42
+ #
43
+ # 直列元号に変換する
44
+ #
45
+ # * 最初の元号:開始日~その元号の終了日
46
+ # * 中間の元号:その元号の開始日~その元号の終了日
47
+ # * 最後の元号:その元号の開始日~終了日
48
+ #
49
+ # @param [Western::Calendar] start_date 西暦開始日
50
+ # @param [Western::Calendar] last_date 西暦終了日
51
+ # @param [Array<Counter>] gengou_list 元号リスト
52
+ #
53
+ # @return [Array<Base::LinearGengou>] 元号リスト
54
+ #
55
+ def self.to_linear_gengou(start_date:, last_date:, gengou_list: [])
56
+ return [] if gengou_list.size.zero?
57
+
58
+ result = []
59
+
60
+ gengou_list.each do |gengou|
61
+ if gengou.invalid?
62
+ # 無効元号は無効のままにする
63
+ result.push(Base::LinearGengou.new)
64
+ next
65
+ end
66
+
67
+ linear_gengou = to_limited_linear_gengou(
68
+ start_date: start_date,
69
+ last_date: last_date,
70
+ gengou: gengou
71
+ )
72
+ result.push(linear_gengou)
73
+ end
74
+
75
+ result
76
+ end
77
+
78
+ #
79
+ # 範囲を限定した直列元号に変換する
80
+ #
81
+ # * 開始日・終了日により範囲を狭める
82
+ #
83
+ # @param [Western::Calendar] start_date 西暦開始日
84
+ # @param [Western::Calendar] last_date 西暦終了日
85
+ # @param [Counter] gengou 加算元号
86
+ #
87
+ # @return [Base::LinearGengou] 元号
88
+ #
89
+ def self.to_limited_linear_gengou(start_date:, last_date:, gengou:)
90
+ gengou_start_date = gengou.western_start_date.clone
91
+ gengou_last_date = gengou.western_last_date.clone
92
+
93
+ gengou_start_date = start_date.clone if start_date > gengou_start_date
94
+ gengou_last_date = last_date.clone if last_date < gengou_last_date
95
+
96
+ Base::LinearGengou.new(
97
+ start_date: gengou_start_date, last_date: gengou_last_date,
98
+ name: gengou.name, year: gengou.japan_year
99
+ )
100
+ end
101
+ end
102
+ end
103
+ end
104
+ end