mirror of
https://github.com/scratchfoundation/scratch-l10n.git
synced 2025-01-08 13:42:11 -05:00
Fix placeholder checking
The placeholder checking didn’t work if the translation’s grammar generated a different number of parsed elements. E.g., in English: something {placeholder} — two elements translation something {placeholder} something — three elements I determined that placeholders are always array elements in the parsed array, so filter for Array elements and check that there are the same number of array elements.
This commit is contained in:
parent
7f7604659c
commit
7d38349a59
1 changed files with 23 additions and 5 deletions
|
@ -9,12 +9,30 @@ const flattenJson = (translations) => {
|
||||||
return JSON.stringify(messages, null, 4);
|
return JSON.stringify(messages, null, 4);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
// filter placeholders out of a message
|
||||||
|
// parse('a message with a {value} and {count, plural, one {one} other {more}}.')
|
||||||
|
// returns an array:
|
||||||
|
// [ 'a message with a ',
|
||||||
|
// [ 'value' ],
|
||||||
|
// ' and ',
|
||||||
|
// [ 'count', 'plural', 0, { one: [Array], other: [Array] } ],
|
||||||
|
// '.'
|
||||||
|
// ]
|
||||||
|
// placeholders are always an array, so filter for array elements to find the placeholders
|
||||||
|
const placeholders = message => (
|
||||||
|
// this will throw an error if the message is not valid ICU
|
||||||
|
parse(message).filter(item => Array.isArray(item))
|
||||||
|
);
|
||||||
|
|
||||||
const validMessage = (message, source) => {
|
const validMessage = (message, source) => {
|
||||||
// this will throw an error if the message is not valid icu
|
const transPlaceholders = placeholders(message);
|
||||||
const t = parse(message);
|
const srcPlaceholders = placeholders(source);
|
||||||
const s = parse(source);
|
// different number of placeholders
|
||||||
// the syntax tree for both messages should have the same number of elements
|
if (transPlaceholders.length !== srcPlaceholders.length) {
|
||||||
return t.length === s.length;
|
return false;
|
||||||
|
}
|
||||||
|
// TODO: Add checking to make sure placeholders in source have not been translated
|
||||||
|
return true;
|
||||||
};
|
};
|
||||||
|
|
||||||
const validateTranslations = (translation, source) => {
|
const validateTranslations = (translation, source) => {
|
||||||
|
|
Loading…
Reference in a new issue