zakuro 0.9.2 → 0.9.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (52) hide show
  1. checksums.yaml +4 -4
  2. data/README.md +1 -1
  3. data/VERSION +1 -1
  4. data/doc/dropped_date.md +25 -0
  5. data/doc/operation/csv/month.csv +1 -1
  6. data/doc/operation/operation.xlsx +0 -0
  7. data/doc/vanished_date.md +26 -0
  8. data/lib/zakuro/calculation/cycle/abstract_remainder.rb +26 -0
  9. data/lib/zakuro/calculation/cycle/abstract_solar_term.rb +1 -1
  10. data/lib/zakuro/calculation/era/gengou/dated_scroll.rb +6 -2
  11. data/lib/zakuro/calculation/era/gengou/internal/counter.rb +5 -5
  12. data/lib/zakuro/calculation/era/gengou/internal/reserve/abstract_list.rb +12 -5
  13. data/lib/zakuro/calculation/era/gengou/internal/reserve/abstract_range.rb +9 -3
  14. data/lib/zakuro/calculation/era/gengou/internal/reserve/dated_list.rb +3 -2
  15. data/lib/zakuro/calculation/era/gengou/internal/reserve/dated_range.rb +4 -2
  16. data/lib/zakuro/calculation/era/gengou/internal/reserve/named_list.rb +5 -3
  17. data/lib/zakuro/calculation/era/gengou/internal/reserve/named_range.rb +9 -4
  18. data/lib/zakuro/calculation/era/gengou/named_scroll.rb +5 -2
  19. data/lib/zakuro/calculation/monthly/initialized_month.rb +4 -2
  20. data/lib/zakuro/calculation/monthly/meta/all_solar_term.rb +64 -0
  21. data/lib/zakuro/calculation/monthly/meta/meta_collector.rb +80 -0
  22. data/lib/zakuro/calculation/monthly/meta.rb +60 -0
  23. data/lib/zakuro/calculation/monthly/month.rb +60 -5
  24. data/lib/zakuro/calculation/monthly/operated_month.rb +5 -19
  25. data/lib/zakuro/calculation/option/dropped_date/location.rb +12 -23
  26. data/lib/zakuro/calculation/option/vanished_date/location.rb +9 -2
  27. data/lib/zakuro/calculation/range/abstract_full_range.rb +19 -2
  28. data/lib/zakuro/calculation/range/abstract_operation_range.rb +20 -2
  29. data/lib/zakuro/calculation/range/dated_full_range.rb +3 -1
  30. data/lib/zakuro/calculation/range/dated_operation_range.rb +3 -1
  31. data/lib/zakuro/calculation/range/medieval_annual_range.rb +1 -1
  32. data/lib/zakuro/calculation/range/named_full_range.rb +3 -1
  33. data/lib/zakuro/calculation/range/named_operation_range.rb +3 -1
  34. data/lib/zakuro/calculation/range/transfer/gengou_scroller.rb +2 -1
  35. data/lib/zakuro/calculation/range/transfer/year_boundary.rb +10 -8
  36. data/lib/zakuro/calculation/stella/solar/abstract_average.rb +8 -34
  37. data/lib/zakuro/calculation/summary/internal/option.rb +24 -5
  38. data/lib/zakuro/calculation/summary/western/specifier/single_day.rb +1 -1
  39. data/lib/zakuro/era/japan/gengou/alignment/linear_gengou.rb +1 -1
  40. data/lib/zakuro/era/japan/gengou/alignment.rb +14 -2
  41. data/lib/zakuro/era/japan/gengou/resource/parser.rb +83 -25
  42. data/lib/zakuro/era/japan/gengou/resource/type.rb +81 -26
  43. data/lib/zakuro/era/japan/gengou/resource/validator.rb +100 -21
  44. data/lib/zakuro/era/japan/gengou/resource/yaml/set-001-until-south.yaml +1123 -375
  45. data/lib/zakuro/era/japan/gengou/resource/yaml/set-002-from-north.yaml +487 -163
  46. data/lib/zakuro/era/japan/gengou/resource/yaml/set-003-modern.yaml +30 -10
  47. data/lib/zakuro/era/japan/gengou/resource.rb +16 -0
  48. data/lib/zakuro/era/japan/gengou.rb +7 -4
  49. data/lib/zakuro/operation/yaml/month.yaml +1 -1
  50. data/lib/zakuro/output/logger.rb +21 -3
  51. data/lib/zakuro/tools/remainder_comparer.rb +97 -0
  52. metadata +6 -2
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: eef9c974d34a357b894544e6fdd53aa5fd2b33e6586c82dd1358ffc899b1ea7b
4
- data.tar.gz: 190feb3886ad674687408879ee217a7a9e345c4c18d01df5ab933696ab8c531d
3
+ metadata.gz: 79211341aba598e1c98e7b3df3ffe0ce6f3016027fe0b2459bd2c68a18703e89
4
+ data.tar.gz: 17d2537acf7d477b6292d1b14e02dbd355499d1c12cf2491e419124108175d9b
5
5
  SHA512:
6
- metadata.gz: 0741d6b76105d9d68fb7ecd871020e960069e8c4db157731c516262ee9ff402a269321e9ca977036e04aaa33a9567f372d10263b8b6067929d449cbb6c0a4bb3
7
- data.tar.gz: e804acf9242d08991f4a6eb92e8f72604b60fc00895257014e87535511bd4cac5a3563fb87cb0bf25fef478e8784c908d76d4953c56343b3ca81e212aee127a2
6
+ metadata.gz: '0196f4cd32a1b8b2d9d517ead1abf747f3be612d59514f68ef75670169c17da9e5222b8d1b63504520653aca6646a840a46b052246d192d27e22146372b52e14'
7
+ data.tar.gz: 8a9f4e91afd4d07868a470e8e372bd0534ddc9f72e55551febc3aba3970b589c896cf0ca8555e1bb71f1606d78078eabd5f70f5125b1680fd1e0b1eaeece9b54
data/README.md CHANGED
@@ -109,7 +109,7 @@ Or install it yourself as:
109
109
  |項目 |有無|
110
110
  |:----|:----|
111
111
  |[没日](./doc/dropped_date.md)|✓|
112
- |滅日|-|
112
+ |[滅日](./doc/vanished_date.md)|✓|
113
113
 
114
114
  # 例外
115
115
 
data/VERSION CHANGED
@@ -1 +1 @@
1
- 0.9.2
1
+ 0.9.3
data/doc/dropped_date.md CHANGED
@@ -132,3 +132,28 @@ p.2055-2056
132
132
  #### 没余上限
133
133
 
134
134
  `策餘` (15943)
135
+
136
+
137
+ # 備考
138
+
139
+ ## 二十四節気の引き当て
140
+ 『日本暦日便覧』により、対応する二十四節気nは大余を基準に引き当てる
141
+
142
+ * 二十四節気nの大余 <= 当日の大余(定朔 + 日数 - 1) < 二十四節気n + 1の大余
143
+ * 例外として、定朔の小余と秒が0の場合に限り、次のように計算する
144
+ * 二十四節気nの大余 <= 当日の大余(定朔 + 日数 - 1) < (二十四節気n + 1の大余) + 1
145
+ * 下記計算結果によりこのようになった
146
+ * 貞観12年7月18日
147
+ * 天喜5年3月11日
148
+ * 寛元1年11月4日
149
+ * 永享2年7月26日
150
+ * 元和3年3月19日
151
+
152
+ ## 『日本暦日原典』との照合
153
+ 『日本暦日便覧』は初版を参考にしているものと思われるが、当ライブラリは第四版に準拠するため、次のような相違が見られる
154
+
155
+ | 西暦日 | 和暦日(初版) | 和暦日(第四版) | 備考 |
156
+ | ---------- | ---------------- | ---------------- | ------------------ |
157
+ | 0807-11-29 | 大同2年10月27日 | 大同2年10月26日 | 第四版のみ注釈あり |
158
+ | 0810-12-17 | 弘仁1年11月18日 | 弘仁1年11月17日 | 第四版のみ注釈あり |
159
+ | 0823-12-05 | 弘仁14年10月30日 | 弘仁14年10月29日 | 初版のみ注釈あり |
@@ -95,7 +95,7 @@
95
95
  ,125-1-a,-,125-1-1,125,-,779-4-21,宝亀 10年 4 大 辛未 7-1700,-,-,true,次月大小,-,-,小,大,-,-,-,-,-,-,-,-,-,-,-,-,-,-,-,-,-
96
96
  ,125-1-1,-,-,125,1,779-5-20,宝亀 10年 5 小 辛丑 36-2820,計算では36庚子であるが続日本紀4月に庚子の記事があるから進朔して37辛丑,5月朔のユリウス暦日は5月21日となる。,-,true,朔日相違,-,-,大,小,-,-,-,-,-,-,庚子,辛丑,779-5-20,779-5-21,36,37,1,1,-,-,-
97
97
  ,125-2-a,-,125-2-1,125,-,779-12-13,宝亀 10年 11 大 丁卯 3-54,-,-,true,次月大小,-,-,小,大,-,-,-,-,-,-,-,-,-,-,-,-,-,-,-,-,-
98
- ,125-2-1,-,-,125,2,780-1-11,宝亀 10年 12 大 丁酉 32-2481,計算では32丙申であるが翌月の正月が続日本紀によると丁卯朔となっているから,12月丁酉朔にしないと12月が31日になる。したがって12月朔のユリウス暦日は1月12日。,-,true,朔日相違,-,-,大,小,-,-,-,-,-,-,丙申,丁酉,780-1-11,780-1-12,32,33,1,1,-,-,-
98
+ ,125-2-1,-,-,125,2,780-1-11,宝亀 10年 12 大 丁酉 32-2481,計算では32丙申であるが翌月の正月が続日本紀によると丁卯朔となっているから,12月丁酉朔にしないと12月が31日になる。したがって12月朔のユリウス暦日は1月12日。,-,true,朔日相違,-,-,大,大,-,-,-,-,-,-,丙申,丁酉,780-1-11,780-1-12,32,33,1,1,-,-,-
99
99
  ,125-3-1,-,-,125,3,780-2-10,宝亀 11年 1 小 丁卯 2-1828,計算では2丙寅,続日本紀は正月朔丁卯,したがって正月朔のユリウス暦日は2月11日。,-,true,朔日相違,-,-,大,小,-,-,-,-,-,-,丙寅,丁卯,780-2-10,780-2-11,2,3,1,1,-,-,-
100
100
  ,125-4-a,-,125-4-1,125,-,780-3-11,宝亀 11年 2 大 丙申 32-954,-,-,true,次月大小,-,-,小,大,-,-,-,-,-,-,-,-,-,-,-,-,-,-,-,-,-
101
101
  ,125-4-1,-,-,125,4,780-4-9,宝亀 11年 3 小 丙寅 1-2852,計算では1乙丑,続日本紀は3月朔丙寅,したがって3月朔のユリウス暦日は4月10日。,日本暦日原典の誤り。「したがって正月朔」ではなく「したがって3月朔」,true,朔日相違,-,-,大,小,-,-,-,-,-,-,乙丑,丙寅,780-4-9,780-4-10,1,2,1,1,-,-,-
Binary file
data/doc/vanished_date.md CHANGED
@@ -84,3 +84,29 @@ p.2055-2056
84
84
  #### 小余倍率
85
85
 
86
86
  `倍参伍` (2 * 3 * 5) = 30
87
+
88
+ # 備考
89
+
90
+ ## 前月経朔の引き当て
91
+ 『日本暦日便覧』により、前月からの経朔で計算するパターンがある
92
+
93
+ | 天平神護3年3月1日 | 寛平3年5月1日 | 長寛2年11月1日 | 貞治4年閏9月1日 | 永正2年10月1日 | 寛文7年1月1日 |
94
+ | 宝亀6年2月1日 | 天延3年12月1日 | 仁安3年11月1日 | 応安6年9月1日 | 永正10年9月1日 | 延宝2年12月1日 |
95
+ | 承和2年12月1日 | 永観1年11月1日 | 安元2年10月1日 | 永徳1年8月1日 | 天文11年10月1日 | 天和2年11月1日 |
96
+ | 承和10年11月1日 | 正暦2年10月1日 | 元久1年7月1日 | 康応1年7月1日 | 天文19年9月1日 | |
97
+ | 仁寿1年10月1日 | 長保1年9月1日 | 建暦2年6月1日 | 応永4年6月1日 | 永禄1年8月1日 | |
98
+ | 貞観1年9月1日 | 寛弘4年8月1日 | 延慶1年11月1日 | 応永12年5月1日 | 永禄9年8月1日 | |
99
+ | 貞観9年8月1日 | 長和4年7月1日 | 正和1年11月1日 | 応永20年4月1日 | 天正2年7月1日 | |
100
+ | 貞観17年7月1日 | 康平3年7月1日 | 正和5年閏10月1日 | 延徳1年12月1日 | 天正10年6月1日 | |
101
+ | 元慶7年6月1日 | 治暦4年6月1日 | 元応2年10月1日 | 明応6年11月1日 | 天正18年5月1日 | |
102
+
103
+ もし当月の経朔で計算できない場合は、前月からの経朔で計算している
104
+
105
+ ## 『日本暦日原典』との照合
106
+ 『日本暦日便覧』は初版を参考にしているものと思われるが、当ライブラリは第四版に準拠するため、次のような相違が見られる
107
+
108
+ | 西暦日 | 和暦日(初版) | 和暦日(第四版) | 備考 |
109
+ | ---------- | ---------------- | ---------------- | ----------------------------------------------- |
110
+ | 0807-11-27 | 大同2年10月24日 | 大同2年10月23日 | 第四版のみ注釈あり |
111
+ | 0823-12-03 | 弘仁14年10月27日 | 弘仁14年10月26日 | 初版のみ注釈あり |
112
+ | 0794-06-21 | 延暦13年5月19日 | 延暦13年5月18日 | 初版/第四版の注釈相違。第四版では運用値に寄せる |
@@ -163,6 +163,22 @@ module Zakuro
163
163
  clone.set(day: sum_day, minute: sum_minute, second: sum_second)
164
164
  end
165
165
 
166
+ #
167
+ # (非破壊的に)大余のみを加算する
168
+ #
169
+ # @param [Integer] term 他の大余
170
+ #
171
+ # @return [AbstractRemainder] 加算結果
172
+ #
173
+ def add_day(term)
174
+ sum_day = day + term
175
+ sum_day, sum_minute, sum_second = carry(
176
+ sum_day, minute, second
177
+ )
178
+
179
+ clone.set(day: sum_day, minute: sum_minute, second: sum_second)
180
+ end
181
+
166
182
  #
167
183
  # (破壊的に)加算する
168
184
  #
@@ -438,6 +454,16 @@ module Zakuro
438
454
  self
439
455
  end
440
456
 
457
+ #
458
+ # 大余のみか
459
+ #
460
+ # @return [True] 大余のみ
461
+ # @return [False] 小余、秒あり
462
+ #
463
+ def only_day?
464
+ minute.zero? && second.zero?
465
+ end
466
+
441
467
  #
442
468
  # 特定の文字フォーマットにして出力する
443
469
  #
@@ -141,7 +141,7 @@ module Zakuro
141
141
  #
142
142
  def prev_term
143
143
  @index -= 1
144
- @index = 23 if index.negative?
144
+ @index = ORDER.size - 1 if index.negative?
145
145
 
146
146
  remainder.sub(average)
147
147
  end
@@ -19,9 +19,13 @@ module Zakuro
19
19
  #
20
20
  # @param [Western::Calendar] start_date 西暦開始日(最大範囲)
21
21
  # @param [Western::Calendar] last_date 西暦終了日(最大範囲)
22
+ # @param [True, False] operated 運用値設定
22
23
  #
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)
24
+ def initialize(start_date: Western::Calendar.new, last_date: Western::Calendar.new,
25
+ operated: false)
26
+ range = Reserve::DatedRange.new(
27
+ start_date: start_date, last_date: last_date, operated: operated
28
+ )
25
29
  super(range: range)
26
30
  end
27
31
  end
@@ -41,8 +41,8 @@ module Zakuro
41
41
  japan_year: INVALID_YEAR)
42
42
  @gengou = gengou
43
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
44
+ @japan_year = gengou.start_year.japan if @japan_year == INVALID_YEAR
45
+ @western_year = gengou.start_year.western
46
46
 
47
47
  @start_date = start_date.clone
48
48
  @last_date = last_date.clone
@@ -58,7 +58,7 @@ module Zakuro
58
58
  def japan_start_date
59
59
  return Japan::Calendar.new if gengou.invalid?
60
60
 
61
- gengou.both_start_date.japan
61
+ gengou.start_date.japan
62
62
  end
63
63
 
64
64
  #
@@ -187,7 +187,7 @@ module Zakuro
187
187
  def select_valid_date
188
188
  return if gengou.invalid?
189
189
 
190
- @start_date = gengou.both_start_date.western.clone if start_date.invalid?
190
+ @start_date = gengou.start_date.western.clone if start_date.invalid?
191
191
  @last_date = gengou.last_date.clone if last_date.invalid?
192
192
  end
193
193
 
@@ -197,7 +197,7 @@ module Zakuro
197
197
  # @return [Western::Calendar]設定された元号の開始日
198
198
  #
199
199
  def native_start_date
200
- gengou.both_start_date.western
200
+ gengou.start_date.western
201
201
  end
202
202
 
203
203
  #
@@ -33,6 +33,9 @@ module Zakuro
33
33
  attr_reader :start_date
34
34
  # @return [Western::Calendar] 終了日
35
35
  attr_reader :last_date
36
+ # @return [True] 運用値あり
37
+ # @return [True] 運用値なし
38
+ attr_reader :operated
36
39
  # @return [Array<Japan::Alignment::LinearGengou>] 予約元号一覧
37
40
  attr_reader :list
38
41
 
@@ -42,12 +45,14 @@ module Zakuro
42
45
  # @param [Integer] index n行目元号
43
46
  # @param [Western::Calendar] start_date 開始日
44
47
  # @param [Western::Calendar] last_date 終了日
48
+ # @param [True, False] operated 運用値設定
45
49
  #
46
50
  def initialize(index:, start_date: Western::Calendar.new,
47
- last_date: Western::Calendar)
51
+ last_date: Western::Calendar, operated: false)
48
52
  @index = index
49
53
  @start_date = start_date.clone
50
54
  @last_date = last_date.clone
55
+ @operated = operated
51
56
  @list = []
52
57
 
53
58
  update
@@ -106,7 +111,7 @@ module Zakuro
106
111
  def japan_start_date
107
112
  return Japan::Calendar.new if invalid?
108
113
 
109
- list[0].gengou.both_start_date.japan.clone
114
+ list[0].gengou.start_date.japan.clone
110
115
  end
111
116
 
112
117
  #
@@ -117,7 +122,7 @@ module Zakuro
117
122
  def western_start_date
118
123
  return Western::Calendar.new if invalid?
119
124
 
120
- list[0].gengou.both_start_date.western.clone
125
+ list[0].gengou.start_date.western.clone
121
126
  end
122
127
 
123
128
  #
@@ -139,7 +144,7 @@ module Zakuro
139
144
  def western_start_year
140
145
  return INVALID_YEAR if invalid?
141
146
 
142
- list[0].gengou.both_start_year.western.clone
147
+ list[0].gengou.start_year.western.clone
143
148
  end
144
149
 
145
150
  #
@@ -210,7 +215,9 @@ module Zakuro
210
215
  # @return [Array<Japan::Alignment::LinearGengou>] 元号
211
216
  #
212
217
  def line(start_date:, last_date:)
213
- Japan::Gengou.line(line: index, start_date: start_date, last_date: last_date)
218
+ Japan::Gengou.line(
219
+ line: index, start_date: start_date, last_date: last_date, operated: operated
220
+ )
214
221
  end
215
222
 
216
223
  #
@@ -26,12 +26,18 @@ module Zakuro
26
26
  #
27
27
  # @param [Western::Calendar] start_date 西暦開始日
28
28
  # @param [Western::Calendar] last_date 西暦終了日
29
+ # @param [True, False] operated 運用値設定
29
30
  #
30
- def initialize(start_date: Western::Calendar.new, last_date: Western::Calendar.new)
31
+ def initialize(start_date: Western::Calendar.new, last_date: Western::Calendar.new,
32
+ operated: false)
31
33
  last_date = start_date.clone if last_date.invalid?
32
34
 
33
- @first_list = DatedList.new(first: true, start_date: start_date, last_date: last_date)
34
- @second_list = DatedList.new(first: false, start_date: start_date, last_date: last_date)
35
+ @first_list = DatedList.new(
36
+ first: true, start_date: start_date, last_date: last_date, operated: operated
37
+ )
38
+ @second_list = DatedList.new(
39
+ first: false, start_date: start_date, last_date: last_date, operated: operated
40
+ )
35
41
 
36
42
  renew(last_date: last_date)
37
43
  end
@@ -21,13 +21,14 @@ module Zakuro
21
21
  # @param [True, False] first true:1行目元号, false:2行目元号
22
22
  # @param [Western::Calendar] start_date 開始日
23
23
  # @param [Western::Calendar] last_date 終了日
24
+ # @param [True, False] operated 運用値設定
24
25
  #
25
26
  def initialize(first: true, start_date: Western::Calendar.new,
26
- last_date: Western::Calendar)
27
+ last_date: Western::Calendar, operated: false)
27
28
  @index = parse_index(first: first)
28
29
  @start_date = start_date.clone
29
30
  @last_date = last_date.invalid? ? start_date.clone : last_date.clone
30
- super(index: @index, start_date: start_date, last_date: last_date)
31
+ super(index: @index, start_date: start_date, last_date: last_date, operated: operated)
31
32
  end
32
33
 
33
34
  #
@@ -19,9 +19,11 @@ module Zakuro
19
19
  #
20
20
  # @param [Western::Calendar] start_date 西暦開始日
21
21
  # @param [Western::Calendar] last_date 西暦終了日
22
+ # @param [True, False] operated 運用値設定
22
23
  #
23
- def initialize(start_date: Western::Calendar.new, last_date: Western::Calendar.new)
24
- super(start_date: start_date, last_date: last_date)
24
+ def initialize(start_date: Western::Calendar.new, last_date: Western::Calendar.new,
25
+ operated: false)
26
+ super(start_date: start_date, last_date: last_date, operated: operated)
25
27
  end
26
28
  end
27
29
  end
@@ -25,13 +25,15 @@ module Zakuro
25
25
  # @param [String] start_name 開始元号名
26
26
  # @param [String] last_name 終了元号名
27
27
  #
28
- def initialize(first: true, start_name: INVALID_NAME, last_name: INVALID_NAME)
28
+ def initialize(first: true, start_name: INVALID_NAME, last_name: INVALID_NAME,
29
+ operated: false)
29
30
  @index = parse_index(first: first)
30
31
  @start_date = Western::Calendar.new
31
32
  @last_date = Western::Calendar.new
33
+ @operated = operated
32
34
 
33
35
  locate(start_name: start_name, last_name: last_name)
34
- super(index: index, start_date: start_date, last_date: last_date)
36
+ super(index: index, start_date: start_date, last_date: last_date, operated: operated)
35
37
  end
36
38
 
37
39
  private
@@ -107,7 +109,7 @@ module Zakuro
107
109
  # @return [Array<Japan::Alignment::LinearGengou>] 元号
108
110
  #
109
111
  def line_by_name(name:)
110
- Japan::Gengou.line_by_name(line: index, name: name)
112
+ Japan::Gengou.line_by_name(line: index, name: name, operated: operated)
111
113
  end
112
114
 
113
115
  #
@@ -23,15 +23,20 @@ module Zakuro
23
23
  #
24
24
  # @param [String] start_name 開始元号名
25
25
  # @param [String] last_name 終了元号名
26
+ # @param [True, False] operated 運用値設定
26
27
  #
27
- def initialize(start_name: INVALID_NAME, last_name: INVALID_NAME)
28
- @first_list = NamedList.new(first: true, start_name: start_name, last_name: last_name)
29
- @second_list = NamedList.new(first: false, start_name: start_name, last_name: last_name)
28
+ def initialize(start_name: INVALID_NAME, last_name: INVALID_NAME, operated: false)
29
+ @first_list = NamedList.new(
30
+ first: true, start_name: start_name, last_name: last_name, operated: operated
31
+ )
32
+ @second_list = NamedList.new(
33
+ first: false, start_name: start_name, last_name: last_name, operated: operated
34
+ )
30
35
 
31
36
  start_date = western_start_date
32
37
  last_date = western_last_date
33
38
 
34
- super(start_date: start_date, last_date: last_date)
39
+ super(start_date: start_date, last_date: last_date, operated: operated)
35
40
  end
36
41
 
37
42
  #
@@ -19,9 +19,12 @@ module Zakuro
19
19
  #
20
20
  # @param [String] start_name 開始元号名
21
21
  # @param [String] last_name 終了元号名
22
+ # @param [True, False] operated 運用値設定
22
23
  #
23
- def initialize(start_name: INVALID_NAME, last_name: INVALID_NAME)
24
- range = Reserve::NamedRange.new(start_name: start_name, last_name: last_name)
24
+ def initialize(start_name: INVALID_NAME, last_name: INVALID_NAME, operated: false)
25
+ range = Reserve::NamedRange.new(
26
+ start_name: start_name, last_name: last_name, operated: operated
27
+ )
25
28
  super(range: range)
26
29
  end
27
30
  end
@@ -31,11 +31,13 @@ module Zakuro
31
31
  # @param [FirstDay] first_day 月初日(朔日)
32
32
  # @param [True, False] is_last_year 昨年の月/今年の月
33
33
  # @param [Integer] phase_index 月齢(朔月、上弦、望月、下弦)
34
+ # @param [Meta] meta 付加情報
34
35
  #
35
36
  def initialize(context:, month_label: MonthLabel.new, solar_terms: [],
36
- first_day: FirstDay.new, is_last_year: false, phase_index: -1)
37
+ first_day: FirstDay.new, is_last_year: false, phase_index: -1,
38
+ meta: Meta.new)
37
39
  super(context: context, month_label: month_label, solar_terms: solar_terms,
38
- first_day: first_day)
40
+ first_day: first_day, meta: meta)
39
41
  @is_last_year = is_last_year
40
42
  @phase_index = phase_index
41
43
  end
@@ -0,0 +1,64 @@
1
+ # frozen_string_literal: true
2
+
3
+ # :nodoc:
4
+ module Zakuro
5
+ # :nodoc:
6
+ module Calculation
7
+ # :nodoc:
8
+ module Monthly
9
+ #
10
+ # AllSolarTerm 月内の全ての二十四節気
11
+ #
12
+ module AllSolarTerm
13
+ class << self
14
+ #
15
+ # 取得する
16
+ #
17
+ # @param [Monthly::Month] before_month 前月
18
+ # @param [Monthly::Month] current_month 当月
19
+ #
20
+ # @return [Array<Cycle::AbstractSolarTerm>] その月の全ての二十四節気
21
+ #
22
+ def get(before_month:, current_month:)
23
+ remainder = current_month.remainder
24
+ solar_terms = current_month.solar_terms
25
+ before_solar_terms = before_month.solar_terms
26
+
27
+ resolve(
28
+ remainder: remainder, solar_terms: solar_terms,
29
+ before_solar_terms: before_solar_terms
30
+ )
31
+ end
32
+
33
+ private
34
+
35
+ #
36
+ # 前月を使用して解決する
37
+ #
38
+ # @param [Cycle::AbstractRemainder] remainder 月初日の大余小余
39
+ # @param [Array<Cycle::AbstractSolarTerm>] solar_terms その月の二十四節気
40
+ # @param [Array<Cycle::AbstractSolarTerm>] before_solar_terms 前月の二十四節気
41
+ #
42
+ # @return [Array<Cycle::AbstractSolarTerm>] その月の全ての二十四節気
43
+ #
44
+ def resolve(remainder:, solar_terms: [], before_solar_terms: [])
45
+ all_solar_terms = solar_terms.clone.each(&:clone)
46
+
47
+ return all_solar_terms if all_solar_terms.empty?
48
+
49
+ first = all_solar_terms[0].clone
50
+
51
+ return all_solar_terms if before_solar_terms.size.zero?
52
+
53
+ # 最初の二十四節気が月初日と同日であれば何もしない
54
+ return all_solar_terms if first.remainder.day == remainder.day
55
+
56
+ all_solar_terms.unshift(before_solar_terms[-1].clone)
57
+
58
+ all_solar_terms
59
+ end
60
+ end
61
+ end
62
+ end
63
+ end
64
+ end
@@ -0,0 +1,80 @@
1
+ # frozen_string_literal: true
2
+
3
+ require_relative '../../../era/western/calendar'
4
+
5
+ require_relative '../month'
6
+
7
+ require_relative './all_solar_term'
8
+
9
+ # :nodoc:
10
+ module Zakuro
11
+ # :nodoc:
12
+ module Calculation
13
+ # :nodoc:
14
+ module Monthly
15
+ #
16
+ # MetaCollector メタ情報の収集
17
+ #
18
+ # 前月データを次のように扱う
19
+ # 1. 範囲内の最初の月は無視する
20
+ # * 元号範囲は常に余裕を持って取っている
21
+ # * 求めたい日付よりは常に1ヶ月以上を計算範囲にしている
22
+ # * 元嘉暦の最初の月は無視する
23
+ # * 元嘉暦は正月始まり
24
+ # * 初めの月は手前の月がないため前月がない
25
+ # * 没日・滅日の対象外のため不要とする
26
+ # 2. 年境界を解決した後の1年データで再度移行する
27
+ # * 冬至データの最初の月には前月がない
28
+ # * 1年データにすることで前月が生まれるので再度移行する
29
+ # 3. 暦の切り替えを考慮する
30
+ # * 手前の月が異なる暦であれば、その月のデータを参照する
31
+ module MetaCollector
32
+ class << self
33
+ #
34
+ # メタ情報を取得する
35
+ #
36
+ # @param [Monthly::Month] before_month 前月
37
+ # @param [Monthly::Month] current_month 当月
38
+ #
39
+ # @return [Monthly::Meta] 当月のメタ情報
40
+ #
41
+ def get(before_month:, current_month:)
42
+ Monthly::Meta.new(
43
+ all_solar_terms: all_solar_terms(
44
+ before_month: before_month, current_month: current_month
45
+ ),
46
+ last_average_remainder: last_average_remainder(
47
+ before_month: before_month
48
+ )
49
+ )
50
+ end
51
+
52
+ private
53
+
54
+ #
55
+ # 全ての二十四節気を取得する
56
+ #
57
+ # @param [Monthly::Month] before_month 前月
58
+ # @param [Monthly::Month] current_month 当月
59
+ #
60
+ # @return [Array<Cycle::AbstractSolarTerm>] その月の全ての二十四節気
61
+ #
62
+ def all_solar_terms(before_month:, current_month:)
63
+ AllSolarTerm.get(before_month: before_month, current_month: current_month)
64
+ end
65
+
66
+ #
67
+ # 前月の経朔を取得する
68
+ #
69
+ # @param [Monthly::Month] before_month 前月
70
+ #
71
+ # @return [Cycle::AbstractRemainder] 前月の経朔
72
+ #
73
+ def last_average_remainder(before_month:)
74
+ before_month.first_day.average_remainder
75
+ end
76
+ end
77
+ end
78
+ end
79
+ end
80
+ end
@@ -0,0 +1,60 @@
1
+ # frozen_string_literal: true
2
+
3
+ require_relative '../cycle/abstract_remainder'
4
+
5
+ # :nodoc:
6
+ module Zakuro
7
+ # :nodoc:
8
+ module Calculation
9
+ # :nodoc:
10
+ module Monthly
11
+ #
12
+ # Meta 付加情報
13
+ #
14
+ class Meta
15
+ # @return [Array<Cycle::AbstractSolarTerm>] 月の全ての二十四節気
16
+ # @note 前提として、『日本暦日原典』にある月ごとの二十四節気は、その月の全ての二十四節気ではない
17
+ #
18
+ # 下表を例に取った場合、『日本暦日原典』の二十四節気連番のうち、2と3がその月の二十四節気となる
19
+ # ここで、当月のうち2より手前の日は前月の1の二十四節気に属しており、当月だけでは参照できない
20
+ # この参照を可能とするための情報となる
21
+ #
22
+ # |No| 項目 | 前月 | 当月 | 次月 |
23
+ # |1 | 月 | month[index - 1] | month[index] | month[index + 1] |
24
+ # |2 | 考えられる範囲 | |-------------------| |
25
+ # |3 | 二十四節気連番 | 0 1 | 2 3 | 4 5 |
26
+ # |4 | 二十四節気大余 | 55 10 | 25 40 | 55 5 |
27
+ #
28
+ attr_reader :all_solar_terms
29
+
30
+ # @return [Cycle::AbstractRemainder] 前月の平朔
31
+ # @note 滅日計算に用いる
32
+ #
33
+ # 月の1日目で前月からの平朔が用いられている
34
+ #
35
+ attr_reader :last_average_remainder
36
+
37
+ #
38
+ # 初期化
39
+ #
40
+ # @param [Array<AbstractSolarTerm>] all_solar_terms 月の全ての二十四節気
41
+ # @param [Cycle::AbstractRemainder] last_average_remainder 前月の平朔
42
+ #
43
+ def initialize(all_solar_terms: [], last_average_remainder: Cycle::AbstractRemainder.new)
44
+ @all_solar_terms = all_solar_terms
45
+ @last_average_remainder = last_average_remainder
46
+ end
47
+
48
+ #
49
+ # ディープコピー
50
+ #
51
+ # @param [Meta] obj 自身
52
+ #
53
+ def initialize_copy(obj)
54
+ @all_solar_terms = obj.all_solar_terms.clone
55
+ @last_average_remainder = obj.last_average_remainder.clone
56
+ end
57
+ end
58
+ end
59
+ end
60
+ end