]> git.openstreetmap.org Git - rails.git/blobdiff - config/initializers/i18n.rb
Monkey patch in an upstream fix for I18n::Backend::Fallbacks
[rails.git] / config / initializers / i18n.rb
index a061d873a2eab5e9b03cc079944bb1794ed978cc..906d59c2d9402f33907fe5da7c78690f04aa9206 100644 (file)
@@ -1,6 +1,45 @@
-require 'globalize/i18n/missing_translations_log_handler'
+module I18n
+  module Backend
+    class Simple
+      module Implementation
+        protected
+        alias_method :old_init_translations, :init_translations
+      
+        def init_translations
+          old_init_translations
 
-I18n.missing_translations_logger = Logger.new("#{RAILS_ROOT}/log/missing_translations.log")
-I18n.exception_handler = :missing_translations_log_handler
+          store_translations(:nb, translations[:no])
+          translations[:no] = translations[:nb]
 
-I18n.backend.add_pluralizer :sl, lambda { |c| c%100 == 1 ? :one : c%100 == 2 ? :two : (3..4).include?(c%100) ? :few : :other }
+          @skip_syntax_deprecation = true
+        end
+      end
+    end
+
+    module Fallbacks
+      def find_first_string_or_lambda_default(defaults)
+        defaults.each_with_index { |default, ix| return ix if default && !default.is_a?(Symbol) }
+        nil
+      end
+    end
+
+    module PluralizationFallback
+      def pluralize(locale, entry, count)
+        super
+      rescue InvalidPluralizationData => ex
+        raise ex unless ex.entry.has_key?(:other)
+        ex.entry[:other]
+      end
+    end
+  end
+end
+
+I18n::Backend::Simple.include(I18n::Backend::Pluralization)
+I18n::Backend::Simple.include(I18n::Backend::PluralizationFallback)
+I18n.load_path << "#{Rails.root}/config/pluralizers.rb"
+
+I18n::Backend::Simple.include(I18n::Backend::Fallbacks)
+
+Rails.configuration.after_initialize do
+  I18n.reload!
+end