]> git.openstreetmap.org Git - rails.git/blobdiff - app/models/language.rb
Merge branch 'master' into moderation
[rails.git] / app / models / language.rb
index a33c76081c786ae594fe86cffea721da6406e812..67e98569bbf14315099efb4b79d40dc7ef32e2ad 100644 (file)
@@ -1,11 +1,36 @@
+# == Schema Information
+#
+# Table name: languages
+#
+#  code         :string           not null, primary key
+#  english_name :string           not null
+#  native_name  :string
+#
+
 class Language < ActiveRecord::Base
 class Language < ActiveRecord::Base
-  set_primary_key :code
+  self.primary_key = "code"
+
+  has_many :diary_entries, :foreign_key => "language"
 
 
-  has_many :diary_entries, :foreign_key => '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
+        end
+      end
+    end
+  end
 
   def name
     name = english_name
     name += " (#{native_name})" unless native_name.nil?
     name
 
   def name
     name = english_name
     name += " (#{native_name})" unless native_name.nil?
     name
-  end  
+  end
 end
 end