X-Git-Url: https://git.openstreetmap.org./rails.git/blobdiff_plain/15b104f4ff4614aa78c01180b6a9b89dd5a1400f..90f1c492271ba8a777988a4b41a53c095af9ae99:/app/models/language.rb?ds=sidebyside diff --git a/app/models/language.rb b/app/models/language.rb index 67e98569b..f1d40feea 100644 --- a/app/models/language.rb +++ b/app/models/language.rb @@ -7,22 +7,18 @@ # native_name :string # -class Language < ActiveRecord::Base - self.primary_key = "code" - - has_many :diary_entries, :foreign_key => "language" +class Language < ApplicationRecord + has_many :diary_entries, :foreign_key => "language", :inverse_of => :language def self.load(file) Language.transaction do - YAML.safe_load(File.read(file)).each do |k, v| - begin - Language.update(k, :english_name => v["english"], :native_name => v["native"]) - rescue ActiveRecord::RecordNotFound - Language.create do |l| - l.code = k - l.english_name = v["english"] - l.native_name = v["native"] - end + YAML.safe_load_file(file).each do |k, v| + Language.update(k, :english_name => v["english"], :native_name => v["native"]) + rescue ActiveRecord::RecordNotFound + Language.create do |l| + l.code = k + l.english_name = v["english"] + l.native_name = v["native"] end end end @@ -30,7 +26,7 @@ class Language < ActiveRecord::Base def name name = english_name - name += " (#{native_name})" unless native_name.nil? + name += " (#{native_name})" unless native_name.nil? || native_name == english_name name end end