Module: JapaneseCalendar::Era::Calculations

Included in:
JapaneseCalendar::Era, Reflection
Defined in:
lib/japanese_calendar/era/calculations.rb

Overview

Calculations module.

Instance Method Summary collapse

Instance Method Details

#era_name(character = :kanji) ⇒ Object

Returns the Japanese era name (nengo) since 1 January 1873 (Meiji 6).

reiwa = Time.new(2019, 5, 1)   # => 2019-05-01 00:00:00 +0900
reiwa.era_name                 # => "令和"
reiwa.era_name(:romaji)        # => "Reiwa"

heisei = Time.new(1989, 1, 8)  # => 1989-01-08 00:00:00 +0900
heisei.era_name                # => "平成"
heisei.era_name(:romaji)       # => "Heisei"

showa = Time.new(1926, 12, 25) # => 1926-12-25 00:00:00 +0900
showa.era_name                 # => "昭和"
showa.era_name(:romaji)        # => "Showa"

taisho = Time.new(1912, 7, 30) # => 1912-07-30 00:00:00 +0900
taisho.era_name                # => "大正"
taisho.era_name(:romaji)       # => "Taisho"

meiji = Time.new(1873, 1, 1)   # => 1873-01-01 00:00:00 +0900
meiji.era_name                 # => "明治"
meiji.era_name(:romaji)        # => "Meiji"

Raises an error when the Japanese era name cannot be found.

Time.new(1872, 12, 31).era_name # => RuntimeError


48
49
50
51
52
53
54
# File 'lib/japanese_calendar/era/calculations.rb', line 48

def era_name(character = :kanji)
  unless %i[kanji romaji].include?(character)
    raise ArgumentError, 'invalid character'
  end

  current_era.send("#{character}_name")
end

#era_yearObject

Returns the year of the Japanese era since 1 January 1873 (Meiji 6).

Time.new(2019,  5,  1).era_year # => 1
Time.new(2019,  4, 30).era_year # => 31
Time.new(1989,  1,  7).era_year # => 64
Time.new(1926, 12, 24).era_year # => 15
Time.new(1912,  7, 29).era_year # => 45

Raises an error when the year of the Japanese era cannot be found.

Time.new(1872, 12, 31).era_year # => RuntimeError


67
68
69
# File 'lib/japanese_calendar/era/calculations.rb', line 67

def era_year
  year - current_era.beginning_of_period.year + 1
end