forked from glebm/i18n-tasks
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmissing.rb
87 lines (77 loc) · 3.47 KB
/
missing.rb
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
# frozen_string_literal: true
require 'i18n/tasks/command/collection'
module I18n::Tasks
module Command
module Commands
module Missing
include Command::Collection
missing_types = I18n::Tasks::MissingKeys.missing_keys_types
arg :missing_types,
'-t',
"--types #{missing_types * ','}",
Array,
t('i18n_tasks.cmd.args.desc.missing_types', valid: missing_types * ', '),
parser: OptionParsers::Enum::ListParser.new(
missing_types,
proc do |invalid, valid|
I18n.t('i18n_tasks.cmd.errors.invalid_missing_type',
invalid: invalid * ', ', valid: valid * ', ', count: invalid.length)
end
)
cmd :missing,
pos: '[locale ...]',
desc: t('i18n_tasks.cmd.desc.missing'),
args: %i[locales out_format missing_types pattern]
def missing(opt = {})
forest = i18n.missing_keys(**opt.slice(:locales, :base_locale, :types))
if opt[:pattern]
pattern_re = i18n.compile_key_pattern(opt[:pattern])
forest.select_keys! { |full_key, _node| full_key =~ pattern_re }
end
print_forest forest, opt, :missing_keys
:exit1 unless forest.empty?
end
cmd :translate_missing,
pos: '[locale ...]',
desc: t('i18n_tasks.cmd.desc.translate_missing'),
args: [:locales, :locale_to_translate_from, arg(:out_format).from(1), :translation_backend, :pattern]
def translate_missing(opt = {})
missing = i18n.missing_diff_forest opt[:locales], opt[:from]
if opt[:pattern]
pattern_re = i18n.compile_key_pattern(opt[:pattern])
missing.select_keys! { |full_key, _node| full_key =~ pattern_re }
end
backend = opt[:backend].presence || i18n.translation_config[:backend]
translated = i18n.translate_forest missing, from: opt[:from], backend: backend.to_sym
i18n.data.merge! translated
log_stderr t('i18n_tasks.translate_missing.translated', count: translated.leaves.count)
print_forest translated, opt
end
cmd :add_missing,
pos: '[locale ...]',
desc: t('i18n_tasks.cmd.desc.add_missing'),
args: [:locales, :out_format, :pattern, arg(:value) + [{ default: '%{value_or_default_or_human_key}' }],
['--nil-value', 'Set value to nil. Takes precedence over the value argument.']]
# Merge base locale first, as this may affect the value for the other locales
def add_missing(opt = {}) # rubocop:disable Metrics/AbcSize
[
[i18n.base_locale] & opt[:locales],
opt[:locales] - [i18n.base_locale]
].reject(&:empty?).each_with_object(i18n.empty_forest) do |locales, added|
forest = i18n.missing_keys(locales: locales, **opt.slice(:types, :base_locale))
.set_each_value!(opt[:'nil-value'] ? nil : opt[:value])
if opt[:pattern]
pattern_re = i18n.compile_key_pattern(opt[:pattern])
forest.select_keys! { |full_key, _node| full_key =~ pattern_re }
end
i18n.data.merge! forest
added.merge! forest
end.tap do |added|
log_stderr t('i18n_tasks.add_missing.added', count: added.leaves.count)
print_forest added, opt
end
end
end
end
end
end