zakuro 0.7.2 → 0.8.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (136) hide show
  1. checksums.yaml +4 -4
  2. data/README.md +3 -3
  3. data/VERSION +1 -1
  4. data/lib/zakuro/calculation/base/gengou.rb +5 -5
  5. data/lib/zakuro/calculation/base/linear_gengou.rb +5 -5
  6. data/lib/zakuro/calculation/base/operated_year.rb +23 -21
  7. data/lib/zakuro/calculation/base/year.rb +3 -3
  8. data/lib/zakuro/calculation/cycle/abstract_remainder.rb +50 -44
  9. data/lib/zakuro/calculation/cycle/abstract_solar_term.rb +28 -24
  10. data/lib/zakuro/calculation/cycle/zodiac.rb +22 -20
  11. data/lib/zakuro/calculation/era/gengou/abstract_scroll.rb +38 -29
  12. data/lib/zakuro/calculation/era/gengou/internal/connector.rb +4 -4
  13. data/lib/zakuro/calculation/era/gengou/internal/counter.rb +16 -16
  14. data/lib/zakuro/calculation/era/gengou/internal/publisher.rb +74 -72
  15. data/lib/zakuro/calculation/era/gengou/internal/reserve/abstract_list.rb +16 -16
  16. data/lib/zakuro/calculation/era/gengou/internal/reserve/abstract_range.rb +58 -35
  17. data/lib/zakuro/calculation/era/gengou/internal/reserve/dated_list.rb +3 -3
  18. data/lib/zakuro/calculation/era/gengou/internal/reserve/empty_link.rb +111 -113
  19. data/lib/zakuro/calculation/era/gengou/internal/reserve/named_list.rb +6 -6
  20. data/lib/zakuro/calculation/era/gengou/internal/reserve/named_range.rb +7 -9
  21. data/lib/zakuro/calculation/era/gengou/internal/reserve.rb +22 -20
  22. data/lib/zakuro/calculation/era/version/internal/crawler.rb +39 -22
  23. data/lib/zakuro/calculation/era/version/version.rb +12 -10
  24. data/lib/zakuro/calculation/monthly/abstract_lunar_phase.rb +13 -9
  25. data/lib/zakuro/calculation/monthly/const.rb +18 -0
  26. data/lib/zakuro/calculation/monthly/initialized_month.rb +39 -37
  27. data/lib/zakuro/calculation/monthly/month.rb +15 -15
  28. data/lib/zakuro/calculation/monthly/month_label.rb +4 -4
  29. data/lib/zakuro/calculation/monthly/operated_month.rb +36 -85
  30. data/lib/zakuro/calculation/monthly/operated_solar_term.rb +80 -0
  31. data/lib/zakuro/calculation/range/abstract_full_range.rb +34 -21
  32. data/lib/zakuro/calculation/range/abstract_operation_range.rb +109 -107
  33. data/lib/zakuro/calculation/range/medieval_annual_range.rb +64 -63
  34. data/lib/zakuro/calculation/range/operated_solar_term.rb +220 -0
  35. data/lib/zakuro/calculation/range/transfer/gengou_scroller.rb +32 -29
  36. data/lib/zakuro/calculation/range/transfer/year_boundary.rb +115 -117
  37. data/lib/zakuro/calculation/stella/lunar/abstract_location.rb +1 -1
  38. data/lib/zakuro/calculation/stella/lunar/choukei_value.rb +48 -46
  39. data/lib/zakuro/calculation/stella/solar/abstract_average.rb +31 -26
  40. data/lib/zakuro/calculation/stella/solar/abstract_location.rb +5 -5
  41. data/lib/zakuro/calculation/stella/solar/choukei_value.rb +114 -114
  42. data/lib/zakuro/calculation/summary/internal/day.rb +21 -19
  43. data/lib/zakuro/calculation/summary/internal/month.rb +25 -12
  44. data/lib/zakuro/calculation/summary/internal/operation.rb +68 -67
  45. data/lib/zakuro/calculation/summary/internal/option.rb +66 -50
  46. data/lib/zakuro/calculation/summary/japan/range.rb +145 -124
  47. data/lib/zakuro/calculation/summary/japan/single.rb +87 -87
  48. data/lib/zakuro/calculation/summary/japan/specifier/single_day.rb +54 -52
  49. data/lib/zakuro/calculation/summary/japan/specifier/specified_range.rb +34 -0
  50. data/lib/zakuro/calculation/summary/western/range.rb +95 -92
  51. data/lib/zakuro/calculation/summary/western/single.rb +78 -76
  52. data/lib/zakuro/calculation/summary/western/specifier/multiple_day.rb +123 -124
  53. data/lib/zakuro/calculation/summary/western/specifier/single_day.rb +60 -58
  54. data/lib/zakuro/calculation/type/old_float.rb +2 -2
  55. data/lib/zakuro/condition.rb +121 -111
  56. data/lib/zakuro/context/context.rb +1 -1
  57. data/lib/zakuro/context/option.rb +31 -29
  58. data/lib/zakuro/context/version_class_resolver.rb +26 -24
  59. data/lib/zakuro/era/japan/calendar.rb +35 -33
  60. data/lib/zakuro/era/japan/gengou/alignment/aligner.rb +4 -4
  61. data/lib/zakuro/era/japan/gengou/alignment/division.rb +117 -118
  62. data/lib/zakuro/era/japan/gengou/alignment/line.rb +7 -5
  63. data/lib/zakuro/era/japan/gengou/alignment/linear_gengou.rb +20 -14
  64. data/lib/zakuro/era/japan/gengou/alignment.rb +27 -25
  65. data/lib/zakuro/era/japan/gengou/resource/parser.rb +51 -36
  66. data/lib/zakuro/era/japan/gengou/resource/type.rb +39 -37
  67. data/lib/zakuro/era/japan/gengou/resource/validator.rb +34 -32
  68. data/lib/zakuro/era/japan/gengou.rb +28 -26
  69. data/lib/zakuro/era/japan/version.rb +18 -16
  70. data/lib/zakuro/era/western/calendar.rb +102 -90
  71. data/lib/zakuro/exception/case/preset.rb +2 -2
  72. data/lib/zakuro/exception/exception.rb +15 -13
  73. data/lib/zakuro/exception/zakuro_error.rb +1 -1
  74. data/lib/zakuro/gateway/locale/date.rb +2 -2
  75. data/lib/zakuro/gateway/locale/range.rb +3 -3
  76. data/lib/zakuro/gateway/range.rb +1 -1
  77. data/lib/zakuro/gateway/single.rb +13 -2
  78. data/lib/zakuro/merchant.rb +1 -1
  79. data/lib/zakuro/operation/month/parser.rb +252 -251
  80. data/lib/zakuro/operation/month/type.rb +17 -8
  81. data/lib/zakuro/operation/month/validator.rb +148 -144
  82. data/lib/zakuro/operation/operation.rb +38 -36
  83. data/lib/zakuro/output/response.rb +112 -113
  84. data/lib/zakuro/result/operation/month/annotation.rb +2 -2
  85. data/lib/zakuro/result/operation/month/history.rb +2 -2
  86. data/lib/zakuro/result/operation/month.rb +31 -0
  87. data/lib/zakuro/result/operation.rb +39 -0
  88. data/lib/zakuro/result/result.rb +3 -3
  89. data/lib/zakuro/tools/stringifier.rb +66 -64
  90. data/lib/zakuro/tools/typeconv.rb +17 -15
  91. data/lib/zakuro/tools/typeof.rb +15 -13
  92. data/lib/zakuro/version/daien/monthly/lunar_phase.rb +10 -12
  93. data/lib/zakuro/version/daien/range/annual_range.rb +19 -17
  94. data/lib/zakuro/version/daien/stella/lunar/adjustment.rb +42 -39
  95. data/lib/zakuro/version/daien/stella/lunar/localization.rb +16 -14
  96. data/lib/zakuro/version/daien/stella/lunar/value.rb +52 -49
  97. data/lib/zakuro/version/daien/stella/origin/average_november.rb +15 -13
  98. data/lib/zakuro/version/daien/stella/origin/lunar_age.rb +23 -21
  99. data/lib/zakuro/version/daien/stella/origin/winter_solstice.rb +22 -20
  100. data/lib/zakuro/version/daien/stella/solar/adjustment.rb +12 -10
  101. data/lib/zakuro/version/daien/stella/solar/average.rb +53 -51
  102. data/lib/zakuro/version/daien/stella/solar/interval.rb +19 -17
  103. data/lib/zakuro/version/daien/stella/solar/value.rb +13 -11
  104. data/lib/zakuro/version/genka/cycle/remainder.rb +2 -2
  105. data/lib/zakuro/version/genka/monthly/lunar_phase.rb +7 -5
  106. data/lib/zakuro/version/genka/range/annual_range.rb +48 -44
  107. data/lib/zakuro/version/genka/stella/origin/first_term.rb +30 -28
  108. data/lib/zakuro/version/genka/stella/origin/january.rb +22 -20
  109. data/lib/zakuro/version/gihou/monthly/lunar_phase.rb +9 -9
  110. data/lib/zakuro/version/gihou/range/annual_range.rb +19 -17
  111. data/lib/zakuro/version/gihou/stella/lunar/adjustment.rb +42 -39
  112. data/lib/zakuro/version/gihou/stella/lunar/localization.rb +16 -14
  113. data/lib/zakuro/version/gihou/stella/lunar/value.rb +52 -49
  114. data/lib/zakuro/version/gihou/stella/origin/average_november.rb +15 -13
  115. data/lib/zakuro/version/gihou/stella/origin/lunar_age.rb +23 -21
  116. data/lib/zakuro/version/gihou/stella/origin/winter_solstice.rb +24 -22
  117. data/lib/zakuro/version/gihou/stella/solar/adjustment.rb +12 -10
  118. data/lib/zakuro/version/gihou/stella/solar/average.rb +52 -50
  119. data/lib/zakuro/version/gihou/stella/solar/interval.rb +19 -17
  120. data/lib/zakuro/version/gihou/stella/solar/value.rb +13 -11
  121. data/lib/zakuro/version/senmyou/monthly/lunar_phase.rb +10 -10
  122. data/lib/zakuro/version/senmyou/range/annual_range.rb +19 -17
  123. data/lib/zakuro/version/senmyou/stella/lunar/adjustment.rb +42 -38
  124. data/lib/zakuro/version/senmyou/stella/lunar/localization.rb +16 -14
  125. data/lib/zakuro/version/senmyou/stella/lunar/value.rb +39 -36
  126. data/lib/zakuro/version/senmyou/stella/origin/average_november.rb +15 -13
  127. data/lib/zakuro/version/senmyou/stella/origin/lunar_age.rb +23 -21
  128. data/lib/zakuro/version/senmyou/stella/origin/winter_solstice.rb +22 -20
  129. data/lib/zakuro/version/senmyou/stella/solar/adjustment.rb +12 -10
  130. data/lib/zakuro/version/senmyou/stella/solar/average.rb +52 -50
  131. data/lib/zakuro/version/senmyou/stella/solar/interval.rb +19 -17
  132. data/lib/zakuro/version/senmyou/stella/solar/value.rb +13 -11
  133. metadata +12 -9
  134. data/lib/zakuro/calculation/range/operated_solar_terms.rb +0 -218
  135. data/lib/zakuro/result/operation/bundle.rb +0 -44
  136. data/lib/zakuro/result/operation/month/bundle.rb +0 -36
@@ -15,121 +15,121 @@ module Zakuro
15
15
  # @return [Output::Logger] ロガー
16
16
  LOGGER = Output::Logger.new(location: 'solar_choukei')
17
17
 
18
- #
19
- # 補正値を返す
20
- #
21
- # @param [Cycle::AbstractRemainder] remainder 大余小余
22
- # @param [Adjustment::Row] row 24気損益眺朒(ちょうじく)数
23
- #
24
- # @return [Integer] 補正値
25
- #
26
- def self.get(remainder:, row:)
27
- # 損益率/眺朒(ちょうじく)数
28
- # パラメータ:
29
- # a: 眺朒(ちょうじく)数の初日の値
30
- # b: 損益率初日の値
31
- # c: 損益率の毎日の差
32
- # n: 定気の日から数えた日数
33
-
34
- # LOGGER.debug("row.per_day: #{row.per_day}")
35
- # LOGGER.debug("row.stack: #{row.stack}")
36
-
37
- day_stack = calc_day_stack(remainder: remainder, row: row)
38
-
39
- # LOGGER.debug("day_stack: #{day_stack}")
40
-
41
- month_stack = calc_month_stack(row: row, day: remainder.day)
42
-
43
- # LOGGER.debug("month_stack: #{month_stack}")
44
-
45
- # 冬至であれば眺朒数がプラスになり続けて損益率が「益」で、小雪であればマイナスの眺朒数がプラスされ続けて「損」
46
- month_stack + day_stack
18
+ class << self
19
+ #
20
+ # 補正値を返す
21
+ #
22
+ # @param [Cycle::AbstractRemainder] remainder 大余小余
23
+ # @param [Adjustment::Row] row 24気損益眺朒(ちょうじく)数
24
+ #
25
+ # @return [Integer] 補正値
26
+ #
27
+ def get(remainder:, row:)
28
+ # 損益率/眺朒(ちょうじく)数
29
+ # パラメータ:
30
+ # a: 眺朒(ちょうじく)数の初日の値
31
+ # b: 損益率初日の値
32
+ # c: 損益率の毎日の差
33
+ # n: 定気の日から数えた日数
34
+
35
+ # LOGGER.debug("row.per_day: #{row.per_day}")
36
+ # LOGGER.debug("row.stack: #{row.stack}")
37
+
38
+ day_stack = calc_day_stack(remainder: remainder, row: row)
39
+
40
+ # LOGGER.debug("day_stack: #{day_stack}")
41
+
42
+ month_stack = calc_month_stack(row: row, day: remainder.day)
43
+
44
+ # LOGGER.debug("month_stack: #{month_stack}")
45
+
46
+ # 冬至であれば眺朒数がプラスになり続けて損益率が「益」で、小雪であればマイナスの眺朒数がプラスされ続けて「損」
47
+ month_stack + day_stack
48
+ end
49
+
50
+ private
51
+
52
+ #
53
+ # 損益率を求める
54
+ #
55
+ # @param [Remainder] remainder 入定気
56
+ # @param [Adjustment::Row] row 24気損益眺朒(ちょうじく)数
57
+ #
58
+ # @return [Integer] 損益率
59
+ #
60
+ def calc_day_stack(remainder:, row:)
61
+ ratio = calc_ratio(day: remainder.day, per_term: row.per_term, per_day: row.per_day)
62
+
63
+ # LOGGER.debug("ratio.sign: #{ratio.sign}")
64
+ # LOGGER.debug("ratio.abs: #{ratio.abs}")
65
+
66
+ calc_day_stack_from_ratio(
67
+ ratio: ratio, minute: remainder.minute, limit: remainder.base_day
68
+ )
69
+ end
70
+
71
+ #
72
+ # 大余に対応する損益率を求める
73
+ # 損益率 = b + n * c
74
+ #
75
+ # @param [Integer] day 大余
76
+ # @param [Integer] per_term 眺朒(ちょうじく)数
77
+ # @param [Integer] per_day 毎日差
78
+ #
79
+ # @return [Type::OldFloat] 大余に対応する損益率
80
+ #
81
+ def calc_ratio(day:, per_term:, per_day:)
82
+ ratio = Type::OldFloat.new(per_term + day * per_day)
83
+ # 小数点以下は無視する
84
+ ratio.floor!
85
+
86
+ ratio
87
+ end
88
+
89
+ #
90
+ # 小余を含めた損益率を求める
91
+ #
92
+ # @param [Integer] sign 正負(大余に対応する損益率)
93
+ # @param [Integer] ratio 大余に対応する損益率
94
+ # @param [Integer] minute 小余
95
+ #
96
+ # @return [Integer] 小余を含めた損益率
97
+ #
98
+ def calc_day_stack_from_ratio(ratio:, minute:, limit:)
99
+ minute_stack = ratio.abs * minute
100
+ day_stack = (minute_stack / limit).floor
101
+ # 四捨五入
102
+ # NOTE 資料では「この余りが4200をこえていれば切り上げる」とあり「>=」とした
103
+ # 1612年の7月(慶長17年7月)が境界値4200だが、繰り上げを行なっていたため
104
+ day_stack += 1 if minute_stack % limit >= (limit / 2)
105
+ day_stack *= ratio.sign
106
+
107
+ day_stack
108
+ end
109
+
110
+ #
111
+ # 眺朒(ちょうじく)数を求める
112
+ # 眺朒(ちょうじく)数 = a + (n * b) + (1/2)n(n-1)c
113
+ #
114
+ # @param [Adjustment::Row] row 24気損益眺朒(ちょうじく)数
115
+ # @param [Integer] day 大余
116
+ #
117
+ # @return [Integer] 眺朒(ちょうじく)数
118
+ #
119
+ def calc_month_stack(row:, day:)
120
+ # row.stack: 眺朒(ちょうじく)積
121
+ # row.per_term: 眺朒(ちょうじく)数
122
+ # row.per_day: 毎日差
123
+ month_stack = Type::OldFloat.new(
124
+ row.stack + day * row.per_term + \
125
+ (1 / 2.0) * (day * (day - 1) * row.per_day)
126
+ )
127
+ # 切り捨て(プラスマイナスに関わらず小数点以下切り捨て)
128
+ month_stack.floor!
129
+
130
+ month_stack.get
131
+ end
47
132
  end
48
-
49
- #
50
- # 損益率を求める
51
- #
52
- # @param [Remainder] remainder 入定気
53
- # @param [Adjustment::Row] row 24気損益眺朒(ちょうじく)数
54
- #
55
- # @return [Integer] 損益率
56
- #
57
- def self.calc_day_stack(remainder:, row:)
58
- ratio = calc_ratio(day: remainder.day, per_term: row.per_term, per_day: row.per_day)
59
-
60
- # LOGGER.debug("ratio.sign: #{ratio.sign}")
61
- # LOGGER.debug("ratio.abs: #{ratio.abs}")
62
-
63
- calc_day_stack_from_ratio(
64
- ratio: ratio, minute: remainder.minute, limit: remainder.base_day
65
- )
66
- end
67
- private_class_method :calc_day_stack
68
-
69
- #
70
- # 大余に対応する損益率を求める
71
- # 損益率 = b + n * c
72
- #
73
- # @param [Integer] day 大余
74
- # @param [Integer] per_term 眺朒(ちょうじく)数
75
- # @param [Integer] per_day 毎日差
76
- #
77
- # @return [Type::OldFloat] 大余に対応する損益率
78
- #
79
- def self.calc_ratio(day:, per_term:, per_day:)
80
- ratio = Type::OldFloat.new(per_term + day * per_day)
81
- # 小数点以下は無視する
82
- ratio.floor!
83
-
84
- ratio
85
- end
86
- private_class_method :calc_ratio
87
-
88
- #
89
- # 小余を含めた損益率を求める
90
- #
91
- # @param [Integer] sign 正負(大余に対応する損益率)
92
- # @param [Integer] ratio 大余に対応する損益率
93
- # @param [Integer] minute 小余
94
- #
95
- # @return [Integer] 小余を含めた損益率
96
- #
97
- def self.calc_day_stack_from_ratio(ratio:, minute:, limit:)
98
- minute_stack = ratio.abs * minute
99
- day_stack = (minute_stack / limit).floor
100
- # 四捨五入
101
- # NOTE 資料では「この余りが4200をこえていれば切り上げる」とあり「>=」とした
102
- # 1612年の7月(慶長17年7月)が境界値4200だが、繰り上げを行なっていたため
103
- day_stack += 1 if minute_stack % limit >= (limit / 2)
104
- day_stack *= ratio.sign
105
-
106
- day_stack
107
- end
108
- private_class_method :calc_day_stack_from_ratio
109
-
110
- #
111
- # 眺朒(ちょうじく)数を求める
112
- # 眺朒(ちょうじく)数 = a + (n * b) + (1/2)n(n-1)c
113
- #
114
- # @param [Adjustment::Row] row 24気損益眺朒(ちょうじく)数
115
- # @param [Integer] day 大余
116
- #
117
- # @return [Integer] 眺朒(ちょうじく)数
118
- #
119
- def self.calc_month_stack(row:, day:)
120
- # row.stack: 眺朒(ちょうじく)積
121
- # row.per_term: 眺朒(ちょうじく)数
122
- # row.per_day: 毎日差
123
- month_stack = Type::OldFloat.new(
124
- row.stack + day * row.per_term + \
125
- (1 / 2.0) * (day * (day - 1) * row.per_day)
126
- )
127
- # 切り捨て(プラスマイナスに関わらず小数点以下切り捨て)
128
- month_stack.floor!
129
-
130
- month_stack.get
131
- end
132
- private_class_method :calc_month_stack
133
133
  end
134
134
  end
135
135
  end
@@ -13,26 +13,28 @@ module Zakuro
13
13
  # Day 特定日
14
14
  #
15
15
  module Day
16
- #
17
- # 日を取得する
18
- #
19
- # @param [Month] month 月
20
- # @param [Western::Calendar] date 現在西暦日
21
- #
22
- # @return [Calculation::Base::Day] 特定日
23
- #
24
- def self.get(month:, date: Western::Calendar.new)
25
- first_date = month.western_date
26
- days = date - first_date
27
- remainder = month.remainder
28
- remainder = remainder.add(
29
- # 常に参照元のRemainderクラスで生成する
30
- remainder.class.new(day: days, minute: 0, second: 0)
31
- )
16
+ class << self
17
+ #
18
+ # 日を取得する
19
+ #
20
+ # @param [Month] month
21
+ # @param [Western::Calendar] date 現在西暦日
22
+ #
23
+ # @return [Calculation::Base::Day] 特定日
24
+ #
25
+ def get(month:, date: Western::Calendar.new)
26
+ first_date = month.western_date
27
+ days = date - first_date
28
+ remainder = month.remainder
29
+ remainder = remainder.add(
30
+ # 常に参照元のRemainderクラスで生成する
31
+ remainder.class.new(day: days, minute: 0, second: 0)
32
+ )
32
33
 
33
- Calculation::Base::Day.new(
34
- number: days + 1, western_date: date, remainder: remainder
35
- )
34
+ Calculation::Base::Day.new(
35
+ number: days + 1, western_date: date, remainder: remainder
36
+ )
37
+ end
36
38
  end
37
39
  end
38
40
  end
@@ -50,22 +50,16 @@ module Zakuro
50
50
  #
51
51
  def get
52
52
  result = []
53
- first_date = @month.western_date.clone
53
+ first_date = month.western_date.clone
54
54
 
55
- (0..@month.days).each do |index|
55
+ (0..month.days).each do |index|
56
56
  current_date = first_date.clone + index
57
57
 
58
58
  next unless include?(date: current_date)
59
59
 
60
- day = Day.get(month: @month, date: current_date)
60
+ day = single_day(current_date: current_date)
61
61
 
62
- options = Option.create(month: @month, day: day)
63
-
64
- single_day = Output::Response::SingleDay.create(
65
- year: @year, month: @month, day: day, options: options
66
- )
67
-
68
- result.push(single_day)
62
+ result.push(day)
69
63
  end
70
64
 
71
65
  result
@@ -80,12 +74,31 @@ module Zakuro
80
74
  # @return [False] 含まない
81
75
  #
82
76
  def include?(date:)
83
- return false if date < @start_date
77
+ return false if date < start_date
84
78
 
85
- return false if date > @last_date
79
+ return false if date > last_date
86
80
 
87
81
  true
88
82
  end
83
+
84
+ private
85
+
86
+ #
87
+ # 1日データを取得する
88
+ #
89
+ # @param [Western::Calendar] current_date 現在西暦日
90
+ #
91
+ # @return [Result::Data::SingleDay] 1日データ
92
+ #
93
+ def single_day(current_date:)
94
+ day = Day.get(month: month, date: current_date)
95
+
96
+ options = Option.create(month: month, day: day)
97
+
98
+ Output::Response::SingleDay.create(
99
+ year: year, month: month, day: day, options: options
100
+ )
101
+ end
89
102
  end
90
103
  end
91
104
  end
@@ -12,86 +12,87 @@ module Zakuro
12
12
  # Operation 運用情報
13
13
  #
14
14
  module Operation
15
- #
16
- # 運用情報を生成する
17
- #
18
- # @param [Result::Data::SingleDay] calc_date 和暦日(計算値)
19
- #
20
- # @return [Result::Operation::Bundle] 運用情報
21
- #
22
- def self.create(calc_date: Result::Data::SingleDay.new)
23
- first_day = calc_date.month.first_day.western_date
24
- operation_history = Zakuro::Operation.specify_history(western_date: first_day)
15
+ class << self
16
+ #
17
+ # 運用情報を生成する
18
+ #
19
+ # @param [Result::Data::SingleDay] calc_date 和暦日(計算値)
20
+ #
21
+ # @return [Result::Operation] 運用情報
22
+ #
23
+ def create(calc_date: Result::Data::SingleDay.new)
24
+ first_day = calc_date.month.first_day.western_date
25
+ operation_history = Zakuro::Operation.specify_history(western_date: first_day)
25
26
 
26
- operation_month = create_operation_month(operation_history: operation_history)
27
+ operation_month = create_operation_month(operation_history: operation_history)
27
28
 
28
- Result::Operation::Bundle.new(
29
- operated: !operation_history.invalid?, month: operation_month, original: calc_date
30
- )
31
- end
29
+ Result::Operation.new(
30
+ operated: !operation_history.invalid?, month: operation_month, original: calc_date
31
+ )
32
+ end
32
33
 
33
- #
34
- # 月履歴集約情報を生成する
35
- #
36
- # @param [Operation::MonthHistory] operation_history 変更履歴(月)
37
- #
38
- # @return [Result::Operation::Month::Bundle] 月履歴集約情報
39
- #
40
- def self.create_operation_month(operation_history: Operation::MonthHistory.new)
41
- return Result::Operation::Month::Bundle.new if operation_history.invalid?
34
+ private
42
35
 
43
- parent_operation_history = Zakuro::Operation.specify_history_by_id(
44
- id: operation_history.parent_id
45
- )
36
+ #
37
+ # 月履歴集約情報を生成する
38
+ #
39
+ # @param [Operation::MonthHistory] operation_history 変更履歴(月)
40
+ #
41
+ # @return [Result::Operation::Month] 月履歴情報
42
+ #
43
+ def create_operation_month(operation_history: Operation::MonthHistory.new)
44
+ return Result::Operation::Month.new if operation_history.invalid?
46
45
 
47
- Result::Operation::Month::Bundle.new(
48
- current: create_operation_month_history(operation_history: operation_history),
49
- parent: create_operation_month_history(operation_history: parent_operation_history)
50
- )
51
- end
52
- private_class_method :create_operation_month
46
+ parent_operation_history = Zakuro::Operation.specify_history_by_id(
47
+ id: operation_history.parent_id
48
+ )
53
49
 
54
- #
55
- # 月別履歴情報を生成する
56
- #
57
- # @param [Operation::MonthHistory] operation_history 変更履歴(月)
58
- #
59
- # @return [Result::Operation::Month::History] 月別履歴情報
60
- #
61
- def self.create_operation_month_history(operation_history: Operation::MonthHistory.new)
62
- return Result::Operation::Month::History.new if operation_history.invalid?
50
+ Result::Operation::Month.new(
51
+ current: create_operation_month_history(operation_history: operation_history),
52
+ parent: create_operation_month_history(operation_history: parent_operation_history)
53
+ )
54
+ end
63
55
 
64
- annotations = create_annnotations(operation_history: operation_history)
56
+ #
57
+ # 月別履歴情報を生成する
58
+ #
59
+ # @param [Operation::MonthHistory] operation_history 変更履歴(月)
60
+ #
61
+ # @return [Result::Operation::Month::History] 月別履歴情報
62
+ #
63
+ def create_operation_month_history(operation_history: Operation::MonthHistory.new)
64
+ return Result::Operation::Month::History.new if operation_history.invalid?
65
65
 
66
- reference = operation_history.reference
67
- Result::Operation::Month::History.new(
68
- id: operation_history.id, western_date: operation_history.western_date.format,
69
- page: reference.page, number: reference.number, annotations: annotations
70
- )
71
- end
72
- private_class_method :create_operation_month_history
66
+ annotations = create_annnotations(operation_history: operation_history)
73
67
 
74
- #
75
- # 注釈情報を生成する
76
- #
77
- # @param [Operation::MonthHistory] operation_history 変更履歴(月)
78
- #
79
- # @return [Array<Result::Operation::Month::Annotation>] 注釈
80
- #
81
- def self.create_annnotations(operation_history: Operation::MonthHistory.new)
82
- annotations = []
83
- operation_history.annotations.each do |annotation|
84
- annotations.push(
85
- Result::Operation::Month::Annotation.new(
86
- description: annotation.description,
87
- note: annotation.note
88
- )
68
+ reference = operation_history.reference
69
+ Result::Operation::Month::History.new(
70
+ id: operation_history.id, western_date: operation_history.western_date.format,
71
+ page: reference.page, number: reference.number, annotations: annotations
89
72
  )
90
73
  end
91
74
 
92
- annotations
75
+ #
76
+ # 注釈情報を生成する
77
+ #
78
+ # @param [Operation::MonthHistory] operation_history 変更履歴(月)
79
+ #
80
+ # @return [Array<Result::Operation::Month::Annotation>] 注釈
81
+ #
82
+ def create_annnotations(operation_history: Operation::MonthHistory.new)
83
+ annotations = []
84
+ operation_history.annotations.each do |annotation|
85
+ annotations.push(
86
+ Result::Operation::Month::Annotation.new(
87
+ description: annotation.description,
88
+ note: annotation.note
89
+ )
90
+ )
91
+ end
92
+
93
+ annotations
94
+ end
93
95
  end
94
- private_class_method :create_annnotations
95
96
  end
96
97
  end
97
98
  end
@@ -16,68 +16,84 @@ module Zakuro
16
16
  # Option オプション
17
17
  #
18
18
  module Option
19
- #
20
- # 初期化
21
- #
22
- # @param [Calculation::Monthly::Month] month 月情報(各暦のデータ型)
23
- # @param [Calculation::Base::Day] day 日情報
24
- #
25
- # @return [Hash<String, Result::Data::Option::AbstractOption>] オプション結果
26
- #
27
- def self.create(month:, day:)
28
- # TODO: test
29
- options = {}
30
- context = month.context
19
+ class << self
20
+ #
21
+ # 初期化
22
+ #
23
+ # @param [Calculation::Monthly::Month] month 月情報(各暦のデータ型)
24
+ # @param [Calculation::Base::Day] day 日情報
25
+ #
26
+ # @return [Hash<String, Result::Data::Option::AbstractOption>] オプション結果
27
+ #
28
+ def create(month:, day:)
29
+ options = {}
30
+ context = month.context
31
31
 
32
- if context.option.dropped_date?
33
- remainder = day.remainder
34
- solar_terms = month.solar_terms
35
- option = dropped_date(context: context, remainder: remainder, solar_terms: solar_terms)
36
- options[Context::Option::DROPPED_DATE_KEY] = option
32
+ if context.option.dropped_date?
33
+ remainder = day.remainder
34
+ solar_terms = month.solar_terms
35
+ option = dropped_date(
36
+ context: context, remainder: remainder, solar_terms: solar_terms
37
+ )
38
+ options[Context::Option::DROPPED_DATE_KEY] = option
39
+ end
40
+
41
+ options
37
42
  end
38
43
 
39
- options
40
- end
44
+ private
45
+
46
+ #
47
+ # 没日を求める
48
+ #
49
+ # @param [Context::Context] context 暦コンテキスト
50
+ # @param [Cycle::AbstractRemainder] remainder 当日和暦日
51
+ # @param [Array<Cycle::AbstractSolarTerm>] solar_terms 二十四節気
52
+ #
53
+ # @return [Result::Data::Option::DroppedDate::Option] 没日
54
+ #
55
+ def dropped_date(context:, remainder:, solar_terms:)
56
+ option = Result::Data::Option::DroppedDate::Option.new(
57
+ matched: false,
58
+ calculation: Result::Data::Option::DroppedDate::Calculation.new
59
+ )
41
60
 
42
- #
43
- # 没日を求める
44
- #
45
- # @param [Context::Context] context 暦コンテキスト
46
- # @param [Cycle::AbstractRemainder] remainder 当日和暦日
47
- # @param [Array<Cycle::AbstractSolarTerm>] solar_terms 二十四節気
48
- #
49
- # @return [Result::Data::Option::DroppedDate::Option] 没日
50
- #
51
- def self.dropped_date(context:, remainder:, solar_terms:)
52
- # TODO: refactor
53
- option = Result::Data::Option::DroppedDate::Option.new(
54
- matched: false,
55
- calculation: Result::Data::Option::DroppedDate::Calculation.new
56
- )
61
+ return option if remainder.invalid?
57
62
 
58
- return option if remainder.invalid?
63
+ location = Calculation::Option::DroppedDate::Location.new(
64
+ context: context, solar_terms: solar_terms
65
+ )
59
66
 
60
- location = Calculation::Option::DroppedDate::Location.new(
61
- context: context, solar_terms: solar_terms
62
- )
67
+ return option unless location.exist?
63
68
 
64
- return option unless location.exist?
69
+ dropped_date = location.get
65
70
 
66
- dropped_date = location.get
71
+ return option unless remainder.day == dropped_date.day
67
72
 
68
- return option unless remainder.day == dropped_date.day
73
+ dropped_date_option(location: location)
74
+ end
69
75
 
70
- solar_term = location.solar_term
71
- Result::Data::Option::DroppedDate::Option.new(
72
- matched: true,
73
- calculation: Result::Data::Option::DroppedDate::Calculation.new(
74
- remainder: dropped_date.format,
75
- solar_term: Result::Data::SolarTerm.new(
76
- index: solar_term.index,
77
- remainder: solar_term.remainder.format
76
+ #
77
+ # 没日オプション値を生成する
78
+ #
79
+ # @param [Calculation::Option::DroppedDate::Location] location 没日位置
80
+ #
81
+ # @return [Result::Data::Option::DroppedDate::Option] 没日オプション値
82
+ #
83
+ def dropped_date_option(location:)
84
+ dropped_date = location.get
85
+ solar_term = location.solar_term
86
+ Result::Data::Option::DroppedDate::Option.new(
87
+ matched: true,
88
+ calculation: Result::Data::Option::DroppedDate::Calculation.new(
89
+ remainder: dropped_date.format,
90
+ solar_term: Result::Data::SolarTerm.new(
91
+ index: solar_term.index,
92
+ remainder: solar_term.remainder.format
93
+ )
78
94
  )
79
95
  )
80
- )
96
+ end
81
97
  end
82
98
  end
83
99
  end