Module: GettextSetup

Defined in:
lib/gettext-setup/pot.rb,
lib/gettext-setup/metadata_pot.rb,
lib/gettext-setup/gettext_setup.rb

Defined Under Namespace

Modules: MetadataPot, Pot Classes: NoConfigFoundError

Class Method Summary collapse

Class Method Details

.add_repository_to_chain(project_name, options) ⇒ Object



67
68
69
70
71
72
73
# File 'lib/gettext-setup/gettext_setup.rb', line 67

def self.add_repository_to_chain(project_name, options)
  repository = FastGettext::TranslationRepository.build(project_name,
                                                        path: locales_path,
                                                        type: options[:file_format] || :po,
                                                        ignore_fuzzy: false)
  @translation_repositories[project_name] = repository unless @translation_repositories.key? project_name
end

.candidate_localesObject

Returns the locale for the current machine. This is most useful for shell applications that need an ACCEPT-LANGUAGE header set.



99
100
101
# File 'lib/gettext-setup/gettext_setup.rb', line 99

def self.candidate_locales
  Locale.candidates(type: :cldr).join(',')
end

.clearObject



103
104
105
# File 'lib/gettext-setup/gettext_setup.rb', line 103

def self.clear
  Locale.clear
end

.configObject



79
80
81
# File 'lib/gettext-setup/gettext_setup.rb', line 79

def self.config
  @config ||= {}
end

.config?Boolean

Returns:

  • (Boolean)

Raises:



61
62
63
64
65
# File 'lib/gettext-setup/gettext_setup.rb', line 61

def self.config?
  raise NoConfigFoundError, File.join(locales_path, 'config.yaml') unless @config

  @config
end

.default_localeObject



87
88
89
# File 'lib/gettext-setup/gettext_setup.rb', line 87

def self.default_locale
  config['default_locale'] || 'en'
end

.default_locale=(new_locale) ⇒ Object



91
92
93
94
95
# File 'lib/gettext-setup/gettext_setup.rb', line 91

def self.default_locale=(new_locale)
  FastGettext.default_locale = new_locale
  Locale.set_default(new_locale)
  config['default_locale'] = new_locale
end

.initialize(locales_path = 'locales', options = {}) ⇒ Object

‘locales_path` should include:

  • config.yaml

  • a .pot file for the project

  • i18n directories for languages, each with a .po file

  • if using .mo files, an LC_MESSAGES dir in each language dir, with the .mo file in it

valid ‘options` fields: :file_format - one of the supported backends for fast_gettext (e.g. :po, :mo, :yaml, etc.)



24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
# File 'lib/gettext-setup/gettext_setup.rb', line 24

def self.initialize(locales_path = 'locales', options = {})
  GettextSetup.initialize_config(locales_path)

  # Make the translation methods available everywhere
  Object.send(:include, FastGettext::Translation)

  # Define our text domain, and set the path into our root.  I would prefer to
  # have something smarter, but we really want this up earlier even than our
  # config loading happens so that errors there can be translated.
  add_repository_to_chain(config['project_name'], options)

  # 'chain' is the only available multi-domain type in fast_gettext 1.1.0 We should consider
  # investigating 'merge' once we can bump our dependency
  FastGettext.add_text_domain('master_domain', type: :chain, chain: @translation_repositories.values)
  FastGettext.default_text_domain = 'master_domain'

  # Likewise, be explicit in our default language choice. Available locales
  # must be set prior to setting the default_locale since default locale must
  # available.
  FastGettext.default_available_locales = (FastGettext.default_available_locales || []) | locales
  FastGettext.default_locale = default_locale

  Locale.set_default(default_locale)
end

.initialize_config(locales_path = 'locales') ⇒ Object

Sets up the config class variables.

Call this without calling initialize when you only need to deal with the translation files and you don’t need runtime translation.



53
54
55
56
57
58
59
# File 'lib/gettext-setup/gettext_setup.rb', line 53

def self.initialize_config(locales_path = 'locales')
  config_path = File.absolute_path('config.yaml', locales_path)
  File.exist?(config_path) || raise(NoConfigFoundError, config_path)

  @config = YAML.load_file(config_path)['gettext']
  @locales_path = locales_path
end

.localesObject



107
108
109
110
111
112
# File 'lib/gettext-setup/gettext_setup.rb', line 107

def self.locales
  explicit = Dir.glob(File.absolute_path('*/*.po', locales_path)).map do |x|
    File.basename(File.dirname(x))
  end
  ([default_locale] + explicit).uniq
end

.locales_pathObject



75
76
77
# File 'lib/gettext-setup/gettext_setup.rb', line 75

def self.locales_path
  @locales_path ||= File.join(Dir.pwd, 'locales')
end

.negotiate_locale(accept_header) ⇒ Object

Given an HTTP Accept-Language header return the locale with the highest priority from it for which we have a locale available. If none exists, return the default locale



117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
# File 'lib/gettext-setup/gettext_setup.rb', line 117

def self.negotiate_locale(accept_header)
  unless @config
    raise ArgumentError, 'No config.yaml found! Use ' \
      '`GettextSetup.initialize(locales_path)` to locate your config.yaml'
  end
  return FastGettext.default_locale if accept_header.nil?

  available_locales = accept_header.split(',').map do |locale|
    pair = locale.strip.split(';q=')
    pair << '1.0' unless pair.size == 2
    # Ignore everything but the language itself; that means that we treat
    # 'de' and 'de-DE' identical, and would use the 'de' message catalog
    # for both.
    pair[0] = pair[0].split('-')[0]
    pair[0] = FastGettext.default_locale if pair[0] == '*'
    pair
  end.sort_by do |(_, qvalue)|
    -1 * qvalue.to_f
  end.select do |(locale, _)|
    FastGettext.available_locales.include?(locale)
  end
  if available_locales && available_locales.first
    available_locales.first.first
  else
    # We can't satisfy the request preference. Just use the default locale.
    default_locale
  end
end

.negotiate_locale!(accept_header) ⇒ Object

Negotiates and sets the locale based on an accept language header.



147
148
149
# File 'lib/gettext-setup/gettext_setup.rb', line 147

def self.negotiate_locale!(accept_header)
  FastGettext.locale = negotiate_locale(accept_header)
end

.translation_repositoriesObject



83
84
85
# File 'lib/gettext-setup/gettext_setup.rb', line 83

def self.translation_repositories
  @translation_repositories
end