module I18n::Backend::CacheFile
Overwrites the Base
load_file
method to cache loaded file contents.
Attributes
Optionally provide path_roots
array to normalize filename paths, to make the cached i18n data portable across environments.
Protected Instance Methods
Track loaded translation files in the ‘i18n.load_file` scope, and skip loading the file if its contents are still up-to-date.
Calls superclass method
# File lib/i18n/backend/cache_file.rb, line 17 def load_file(filename) initialized = !respond_to?(:initialized?) || initialized? key = I18n::Backend::Flatten.escape_default_separator(normalized_path(filename)) old_mtime, old_digest = initialized && lookup(:i18n, key, :load_file) return if (mtime = File.mtime(filename).to_i) == old_mtime || (digest = OpenSSL::Digest::SHA256.file(filename).hexdigest) == old_digest super store_translations(:i18n, load_file: { key => [mtime, digest] }) end
Translate absolute filename to relative path for i18n key.
# File lib/i18n/backend/cache_file.rb, line 28 def normalized_path(file) return file unless path_roots path = path_roots.find(&file.method(:start_with?)) || raise(InvalidLocaleData.new(file, 'outside expected path roots')) file.sub(path, path_roots.index(path).to_s) end