diff options
author | Kir Shatrov <shatrov@me.com> | 2015-08-04 17:53:15 +0200 |
---|---|---|
committer | Kir Shatrov <shatrov@me.com> | 2015-08-10 00:17:49 +0200 |
commit | f50e90a1aeaee0e1e907e51cd2a9349d0af2c087 (patch) | |
tree | a602a07ffa8249e60b4538de3c8c7c4840405aff /activesupport | |
parent | 7a3ca69959e312a215d5e8144fca79a08654fd89 (diff) | |
download | rails-f50e90a1aeaee0e1e907e51cd2a9349d0af2c087.tar.gz rails-f50e90a1aeaee0e1e907e51cd2a9349d0af2c087.tar.bz2 rails-f50e90a1aeaee0e1e907e51cd2a9349d0af2c087.zip |
Reload I18n locales in development
Diffstat (limited to 'activesupport')
-rw-r--r-- | activesupport/lib/active_support/i18n_railtie.rb | 19 |
1 files changed, 17 insertions, 2 deletions
diff --git a/activesupport/lib/active_support/i18n_railtie.rb b/activesupport/lib/active_support/i18n_railtie.rb index 95f3f6255a..6775eec34b 100644 --- a/activesupport/lib/active_support/i18n_railtie.rb +++ b/activesupport/lib/active_support/i18n_railtie.rb @@ -37,10 +37,12 @@ module I18n enforce_available_locales = I18n.enforce_available_locales if enforce_available_locales.nil? I18n.enforce_available_locales = false + reloadable_paths = [] app.config.i18n.each do |setting, value| case setting when :railties_load_path - app.config.i18n.load_path.unshift(*value) + reloadable_paths = value + app.config.i18n.load_path.unshift(*value.map(&:existent).flatten) when :load_path I18n.load_path += value else @@ -53,7 +55,14 @@ module I18n # Restore available locales check so it will take place from now on. I18n.enforce_available_locales = enforce_available_locales - reloader = ActiveSupport::FileUpdateChecker.new(I18n.load_path.dup){ I18n.reload! } + directories = watched_dirs_with_extensions(reloadable_paths) + reloader = ActiveSupport::FileUpdateChecker.new(I18n.load_path.dup, directories) do + I18n.load_path.keep_if { |p| File.exist?(p) } + I18n.load_path |= reloadable_paths.map(&:existent).flatten + + I18n.reload! + end + app.reloaders << reloader ActionDispatch::Reloader.to_prepare do reloader.execute_if_updated @@ -96,5 +105,11 @@ module I18n raise "Unexpected fallback type #{fallbacks.inspect}" end end + + def self.watched_dirs_with_extensions(paths) + paths.each_with_object({}) do |path, result| + result[path.absolute_current] = path.extensions + end + end end end |