Module: I18n::Backend::Flatten

Included in:
KeyValue::Implementation
Defined in:
lib/i18n/backend/flatten.rb

Overview

This module contains several helpers to assist flattening translations. You may want to flatten translations for:

1) speed up lookups, as in the Memoize backend;
2) In case you want to store translations in a data store, as in ActiveRecord backend;

You can check both backends above for some examples. This module also keeps all links in a hash so they can be properly resolved when flattened.

Constant Summary collapse

SEPARATOR_ESCAPE_CHAR =
"\001"
FLATTEN_SEPARATOR =
"."

Class Method Summary collapse

Instance Method Summary collapse

Class Method Details

.escape_default_separator(key) ⇒ Object

Receives a string and escape the default separator.



33
34
35
# File 'lib/i18n/backend/flatten.rb', line 33

def self.escape_default_separator(key) #:nodoc:
  key.to_s.tr(FLATTEN_SEPARATOR, SEPARATOR_ESCAPE_CHAR)
end

.normalize_flat_keys(locale, key, scope, separator) ⇒ Object

normalize_keys the flatten way. This method is significantly faster and creates way less objects than the one at I18n.normalize_keys. It also handles escaping the translation keys.



18
19
20
21
22
23
24
25
26
27
28
29
30
# File 'lib/i18n/backend/flatten.rb', line 18

def self.normalize_flat_keys(locale, key, scope, separator)
  keys = [scope, key].flatten.compact
  separator ||= I18n.default_separator

  if separator != FLATTEN_SEPARATOR
    keys.map! do |k|
      k.to_s.tr("#{FLATTEN_SEPARATOR}#{separator}",
        "#{SEPARATOR_ESCAPE_CHAR}#{FLATTEN_SEPARATOR}")
    end
  end

  keys.join(".")
end

Instance Method Details

#flatten_keys(hash, escape, prev_key = nil, &block) ⇒ Object

Flatten keys for nested Hashes by chaining up keys:

>> { "a" => { "b" => { "c" => "d", "e" => "f" }, "g" => "h" }, "i" => "j"}.wind
=> { "a.b.c" => "d", "a.b.e" => "f", "a.g" => "h", "i" => "j" }


54
55
56
57
58
59
60
61
# File 'lib/i18n/backend/flatten.rb', line 54

def flatten_keys(hash, escape, prev_key=nil, &block)
  hash.each_pair do |key, value|
    key = escape_default_separator(key) if escape
    curr_key = [prev_key, key].compact.join(FLATTEN_SEPARATOR).to_sym
    yield curr_key, value
    flatten_keys(value, escape, curr_key, &block) if value.is_a?(Hash)
  end
end

#flatten_translations(locale, data, escape, subtree) ⇒ Object

Receives a hash of translations (where the key is a locale and the value is another hash) and return a hash with all translations flattened.

Nested hashes are included in the flattened hash just if subtree is true and Symbols are automatically stored as links.



69
70
71
72
73
74
75
76
77
78
79
80
# File 'lib/i18n/backend/flatten.rb', line 69

def flatten_translations(locale, data, escape, subtree)
  hash = {}
  flatten_keys(data, escape) do |key, value|
    if value.is_a?(Hash)
      hash[key] = value if subtree
    else
      store_link(locale, key, value) if value.is_a?(Symbol)
      hash[key] = value
    end
  end
  hash
end

Store flattened links.



45
46
47
# File 'lib/i18n/backend/flatten.rb', line 45

def links
  @links ||= Hash.new { |h,k| h[k] = {} }
end

#normalize_flat_keys(locale, key, scope, separator) ⇒ Object

Shortcut to I18n::Backend::Flatten.normalize_flat_keys and then resolve_links.



39
40
41
42
# File 'lib/i18n/backend/flatten.rb', line 39

def normalize_flat_keys(locale, key, scope, separator)
  key = I18n::Backend::Flatten.normalize_flat_keys(locale, key, scope, separator)
  resolve_link(locale, key)
end