update i18n:stats task to count pluralization based on locale setting
This commit is contained in:
parent
9bb950ab37
commit
b1249df598
|
@ -109,6 +109,8 @@
|
||||||
:wa => { :i18n => { :plural => { :keys => [:one, :other], :rule => lambda { |n| [0, 1].include?(n) ? :one : :other } } } },
|
:wa => { :i18n => { :plural => { :keys => [:one, :other], :rule => lambda { |n| [0, 1].include?(n) ? :one : :other } } } },
|
||||||
:yo => { :i18n => { :plural => { :keys => [:other], :rule => lambda { |n| :other } } } },
|
:yo => { :i18n => { :plural => { :keys => [:other], :rule => lambda { |n| :other } } } },
|
||||||
:zh => { :i18n => { :plural => { :keys => [:other], :rule => lambda { |n| :other } } } },
|
:zh => { :i18n => { :plural => { :keys => [:other], :rule => lambda { |n| :other } } } },
|
||||||
|
:zh_CN => { :i18n => { :plural => { :keys => [:other], :rule => lambda { |n| :other } } } },
|
||||||
|
:zh_TW => { :i18n => { :plural => { :keys => [:other], :rule => lambda { |n| :other } } } },
|
||||||
:zu => { :i18n => { :plural => { :keys => [:one, :other], :rule => lambda { |n| n == 1 ? :one : :other } } } }
|
:zu => { :i18n => { :plural => { :keys => [:one, :other], :rule => lambda { |n| n == 1 ? :one : :other } } } }
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -6,6 +6,13 @@ task "i18n:stats" => :environment do
|
||||||
def to_dotted_hash(source, target = {}, namespace = nil)
|
def to_dotted_hash(source, target = {}, namespace = nil)
|
||||||
prefix = "#{namespace}." if namespace
|
prefix = "#{namespace}." if namespace
|
||||||
if source.kind_of?(Hash)
|
if source.kind_of?(Hash)
|
||||||
|
|
||||||
|
# detect pluralizable string
|
||||||
|
if (source["other"] != nil)
|
||||||
|
target[namespace] = {pluralizable: true, content: source}
|
||||||
|
return
|
||||||
|
end
|
||||||
|
|
||||||
source.each do |key, value|
|
source.each do |key, value|
|
||||||
to_dotted_hash(value, target, "#{prefix}#{key}")
|
to_dotted_hash(value, target, "#{prefix}#{key}")
|
||||||
end
|
end
|
||||||
|
@ -15,7 +22,7 @@ task "i18n:stats" => :environment do
|
||||||
target
|
target
|
||||||
end
|
end
|
||||||
|
|
||||||
def compare(a, b)
|
def compare(a, b, plural_keys)
|
||||||
locale1 = /.*\.([^.]{2,})\.yml$/.match(a)[1]
|
locale1 = /.*\.([^.]{2,})\.yml$/.match(a)[1]
|
||||||
locale2 = /.*\.([^.]{2,})\.yml$/.match(b)[1]
|
locale2 = /.*\.([^.]{2,})\.yml$/.match(b)[1]
|
||||||
|
|
||||||
|
@ -44,9 +51,46 @@ task "i18n:stats" => :environment do
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
a.each do |key,value|
|
||||||
|
if value.kind_of?(Hash)
|
||||||
|
if value[:pluralizable]
|
||||||
|
plural_keys.each do |pl|
|
||||||
|
if b[key] == nil || !b[key].kind_of?(Hash) || b[key][:content][pl] == nil
|
||||||
|
minus << "#{key}.#{pl}"
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
if b[key] != nil && b[key].kind_of?(Hash)
|
||||||
|
b[key][:content].each do |pl,val|
|
||||||
|
if ! plural_keys.include?(pl)
|
||||||
|
if a[key][:content]["zero"] == nil
|
||||||
|
plus << "#{key}.#{pl}"
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
# special handling for zero
|
||||||
|
if a[key][:content]["zero"] != nil
|
||||||
|
if b[key] == nil || !b[key].kind_of?(Hash) || b[key][:content]["zero"] == nil
|
||||||
|
minus << "#{key}.zero"
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
return plus,minus,same,total
|
return plus,minus,same,total
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def get_plurals(locale)
|
||||||
|
if locale == "pseudo"
|
||||||
|
locale = "en"
|
||||||
|
end
|
||||||
|
|
||||||
|
I18n.t("i18n.plural.keys", :locale => locale).map { |x| x.to_s }
|
||||||
|
end
|
||||||
|
|
||||||
puts "Discourse Translation Status Script"
|
puts "Discourse Translation Status Script"
|
||||||
puts "To show details about a specific locale (e.g. 'de'), run as:"
|
puts "To show details about a specific locale (e.g. 'de'), run as:"
|
||||||
puts " rake i18n:stats locale=de"
|
puts " rake i18n:stats locale=de"
|
||||||
|
@ -68,8 +112,10 @@ task "i18n:stats" => :environment do
|
||||||
next if !File.exists?("#{Rails.root}/config/locales/client.#{locale}.yml")
|
next if !File.exists?("#{Rails.root}/config/locales/client.#{locale}.yml")
|
||||||
next if !File.exists?("#{Rails.root}/config/locales/server.#{locale}.yml")
|
next if !File.exists?("#{Rails.root}/config/locales/server.#{locale}.yml")
|
||||||
|
|
||||||
plus1, minus1, same1, total1 = compare("client.en.yml", "client.#{locale}.yml")
|
pluralization_keys = get_plurals(locale)
|
||||||
plus2, minus2, same2, total2 = compare("server.en.yml", "server.#{locale}.yml")
|
|
||||||
|
plus1, minus1, same1, total1 = compare("client.en.yml", "client.#{locale}.yml", pluralization_keys)
|
||||||
|
plus2, minus2, same2, total2 = compare("server.en.yml", "server.#{locale}.yml", pluralization_keys)
|
||||||
puts "%10s %8s %8s %8s %8s %8s %8s %8s %8s" % [locale, plus1.count, minus1.count, same1.count, total1,
|
puts "%10s %8s %8s %8s %8s %8s %8s %8s %8s" % [locale, plus1.count, minus1.count, same1.count, total1,
|
||||||
plus2.count, minus2.count, same2.count, total2]
|
plus2.count, minus2.count, same2.count, total2]
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue