UNPKG

@singleton-i18n/angular-client

Version:

Singleton client code for Angular 10.

238 lines 29.1 kB
/* * Copyright 2019-2021 VMware, Inc. * SPDX-License-Identifier: EPL-2.0 */ const ARG_OPN = '{'; const ARG_CLS = '}'; const ARG_SEP = ','; const NUM_ARG = '#'; const ESC = '\''; export function parse(pattern) { return parseAST({ pattern: String(pattern), index: 0 }, ''); } function parseAST(current, parentType) { const pattern = current.pattern; const length = pattern.length; const elements = []; let text = parseText(current, parentType); if (text) { elements.push(text); } while (current.index < length) { if (pattern[current.index] === ARG_CLS) { if (!parentType) { throw expected(current); } break; } elements.push(parsePlaceholder(current)); text = parseText(current, parentType); if (text) { elements.push(text); } } return elements; } function parseText(current, parentType) { const pattern = current.pattern; const length = pattern.length; const isPlural = parentType === 'plural'; let text = ''; while (current.index < length) { let char = pattern[current.index]; if (char === ARG_OPN || char === ARG_CLS || (isPlural && char === NUM_ARG)) { break; } else if (char === ESC) { char = pattern[++current.index]; if (char === ESC) { text += char; ++current.index; } else if (char === ARG_OPN || char === ARG_CLS || (isPlural && char === NUM_ARG)) { text += char; while (++current.index < length) { char = pattern[current.index]; if (char === ESC && pattern[current.index + 1] === ESC) { // double is always 1 ' text += ESC; ++current.index; } else if (char === ESC) { ++current.index; break; } else { text += char; } } } else { text += ESC; } } else { text += char; ++current.index; } } return text; } function isWhitespace(code) { return ((code >= 0x09 && code <= 0x0D) || code === 0x20 || code === 0x85 || code === 0xA0 || code === 0x180E || (code >= 0x2000 && code <= 0x200D) || code === 0x2028 || code === 0x2029 || code === 0x202F || code === 0x205F || code === 0x2060 || code === 0x3000 || code === 0xFEFF); } function skipWhitespace(current) { const pattern = current.pattern; const length = pattern.length; while (current.index < length && isWhitespace(pattern.charCodeAt(current.index))) { ++current.index; } } function parsePlaceholder(current) { const pattern = current.pattern; if (pattern[current.index] === NUM_ARG) { ++current.index; // move passed # return [NUM_ARG]; } /* istanbul ignore if should be unreachable if parseAST and parseText are right */ if (pattern[current.index] !== ARG_OPN) { throw expected(current, ARG_OPN); } ++current.index; // move passed { skipWhitespace(current); const id = parseId(current); if (!id) { throw expected(current, 'placeholder id'); } skipWhitespace(current); let char = pattern[current.index]; if (char === ARG_CLS) { ++current.index; return [id]; } if (char !== ARG_SEP) { throw expected(current, ARG_SEP + ' or ' + ARG_CLS); } ++current.index; skipWhitespace(current); const type = parseId(current); if (!type) { throw expected(current, 'placeholder type'); } skipWhitespace(current); char = pattern[current.index]; if (char === ARG_CLS) { if (type === 'plural') { throw expected(current, type + ' sub-messages'); } ++current.index; return [id, type]; } if (char !== ARG_SEP) { throw expected(current, ARG_SEP + ' or ' + ARG_CLS); } ++current.index; skipWhitespace(current); let arg; if (type === 'plural') { skipWhitespace(current); arg = [id, type, parseSubMessages(current, type)]; } skipWhitespace(current); if (pattern[current.index] !== ARG_CLS) { throw expected(current, ARG_CLS); } ++current.index; return arg; } function parseId(current) { const pattern = current.pattern; const length = pattern.length; let id = ''; while (current.index < length) { const char = pattern[current.index]; if (char === ARG_OPN || char === ARG_CLS || char === ARG_SEP || char === NUM_ARG || char === ESC || isWhitespace(char.charCodeAt(0))) { break; } id += char; ++current.index; } return id; } function parseSubMessages(current, parentType) { const pattern = current.pattern; const length = pattern.length; const options = {}; while (current.index < length && pattern[current.index] !== ARG_CLS) { const selector = parseId(current); if (!selector) { throw expected(current, 'sub-message selector'); } skipWhitespace(current); const arr = parseSubMessage(current, parentType); options[selector] = arr; skipWhitespace(current); } if (!options['other'] && parentType === 'plural') { throw expected(current, null, null, '"other" sub-message must be specified in plural'); } return options; } function parseSubMessage(current, parentType) { if (current.pattern[current.index] !== ARG_OPN) { throw expected(current, ARG_OPN + ' to start sub-message'); } ++current.index; // move passed { const message = parseAST(current, parentType); if (current.pattern[current.index] !== ARG_CLS) { throw expected(current, ARG_CLS + ' to end sub-message'); } ++current.index; // move passed } return message; } function expected(current, expectedstr, found, message) { const pattern = current.pattern; const lines = pattern.slice(0, current.index).split(/\r?\n/); const offset = current.index; const line = lines.length; const column = lines.slice(-1)[0].length; found = found || ((current.index >= pattern.length) ? 'end of message pattern' : (parseId(current) || pattern[current.index])); if (!message) { message = errorMessage(expectedstr, found); } message += ' in ' + pattern.replace(/\r?\n/g, '\n'); return new MessageSyntaxError(message, expectedstr, found, offset, line, column); } // Error function function errorMessage(expectedstr, found) { if (!expectedstr) { return 'Unexpected ' + found + ' found'; } return 'Expected ' + expectedstr + ' but found ' + found; } /** * SyntaxError * Holds information about bad syntax found in a message pattern **/ function MessageSyntaxError(message, expectedstr, found, offset, line, column) { Error.call(this, message); this.name = 'SyntaxError'; this.message = message; this.expected = expectedstr; this.found = found; this.offset = offset; this.line = line; this.column = column; } MessageSyntaxError.prototype = Object.create(Error.prototype); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"plural.message.parser.js","sourceRoot":"/home/rligeng/Projects/Devops/Client_Angular_GitHub_Npmjs/vip/ci/pub2org/Client_Angular_GitHub_Npmjs/singleton/projects/angular-client/","sources":["src/formatters/plural/plural.message.parser.ts"],"names":[],"mappings":"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","sourcesContent":["/*\n * Copyright 2019-2021 VMware, Inc.\n * SPDX-License-Identifier: EPL-2.0\n */\nconst ARG_OPN = '{';\nconst ARG_CLS = '}';\nconst ARG_SEP = ',';\nconst NUM_ARG = '#';\nconst ESC = '\\'';\ninterface Context {\n    pattern: string;\n    index: number;\n}\n\nexport function parse(\n    pattern: string\n): any[] {\n    return parseAST({\n        pattern: String(pattern),\n        index: 0\n    }, '');\n}\n\nfunction parseAST(current: Context, parentType: string): any[] {\n    const pattern = current.pattern;\n    const length = pattern.length;\n    const elements = [];\n    let text = parseText(current, parentType);\n    if (text) { elements.push(text); }\n    while (current.index < length) {\n        if (pattern[current.index] === ARG_CLS) {\n            if (!parentType) { throw expected(current); }\n            break;\n        }\n        elements.push(parsePlaceholder(current));\n        text = parseText(current, parentType);\n        if (text) { elements.push(text); }\n    }\n    return elements;\n}\n\nfunction parseText(current: Context, parentType: string): string {\n    const pattern = current.pattern;\n    const length = pattern.length;\n    const isPlural = parentType === 'plural';\n    let text = '';\n    while (current.index < length) {\n        let char = pattern[current.index];\n        if (\n            char === ARG_OPN || char === ARG_CLS ||\n            (isPlural && char === NUM_ARG)\n        ) {\n            break;\n        } else if (char === ESC) {\n            char = pattern[++current.index];\n            if (char === ESC) {\n                text += char;\n                ++current.index;\n            } else if (\n                char === ARG_OPN || char === ARG_CLS ||\n                (isPlural && char === NUM_ARG)\n            ) {\n                text += char;\n                while (++current.index < length) {\n                    char = pattern[current.index];\n                    if (char === ESC && pattern[current.index + 1] === ESC) { // double is always 1 '\n                        text += ESC;\n                        ++current.index;\n                    } else if (char === ESC) {\n                        ++current.index;\n                        break;\n                    } else {\n                        text += char;\n                    }\n                }\n            } else {\n                text += ESC;\n            }\n        } else {\n            text += char;\n            ++current.index;\n        }\n    }\n    return text;\n}\n\nfunction isWhitespace(code: number): boolean {\n    return (\n        (code >= 0x09 && code <= 0x0D) ||\n        code === 0x20 || code === 0x85 || code === 0xA0 || code === 0x180E ||\n        (code >= 0x2000 && code <= 0x200D) ||\n        code === 0x2028 || code === 0x2029 || code === 0x202F || code === 0x205F ||\n        code === 0x2060 || code === 0x3000 || code === 0xFEFF\n    );\n}\n\nfunction skipWhitespace(current: Context): void {\n    const pattern = current.pattern;\n    const length = pattern.length;\n    while (current.index < length && isWhitespace(pattern.charCodeAt(current.index))) {\n        ++current.index;\n    }\n}\n\nfunction parsePlaceholder(current: Context)/*: Placeholder */ {\n    const pattern = current.pattern;\n    if (pattern[current.index] === NUM_ARG) {\n        ++current.index; // move passed #\n        return [NUM_ARG];\n    }\n\n    /* istanbul ignore if should be unreachable if parseAST and parseText are right */\n    if (pattern[current.index] !== ARG_OPN) { throw expected(current, ARG_OPN); }\n    ++current.index; // move passed {\n    skipWhitespace(current);\n\n    const id = parseId(current);\n    if (!id) { throw expected(current, 'placeholder id'); }\n    skipWhitespace(current);\n\n    let char = pattern[current.index];\n    if (char === ARG_CLS) {\n        ++current.index;\n        return [id];\n    }\n\n    if (char !== ARG_SEP) { throw expected(current, ARG_SEP + ' or ' + ARG_CLS); }\n    ++current.index;\n    skipWhitespace(current);\n\n    const type = parseId(current);\n    if (!type) { throw expected(current, 'placeholder type'); }\n    skipWhitespace(current);\n    char = pattern[current.index];\n    if (char === ARG_CLS) {\n        if (type === 'plural') {\n            throw expected(current, type + ' sub-messages');\n        }\n        ++current.index;\n        return [id, type];\n    }\n\n    if (char !== ARG_SEP) { throw expected(current, ARG_SEP + ' or ' + ARG_CLS); }\n    ++current.index;\n    skipWhitespace(current);\n\n    let arg;\n    if (type === 'plural') {\n        skipWhitespace(current);\n        arg = [id, type, parseSubMessages(current, type)];\n    }\n\n    skipWhitespace(current);\n    if (pattern[current.index] !== ARG_CLS) { throw expected(current, ARG_CLS); }\n    ++current.index;\n\n\n    return arg;\n}\n\nfunction parseId(current: Context): string {\n    const pattern = current.pattern;\n    const length = pattern.length;\n    let id = '';\n    while (current.index < length) {\n        const char = pattern[current.index];\n        if (\n            char === ARG_OPN || char === ARG_CLS || char === ARG_SEP ||\n            char === NUM_ARG || char === ESC || isWhitespace(char.charCodeAt(0))\n        ) { break; }\n        id += char;\n        ++current.index;\n    }\n    return id;\n}\n\nfunction parseSubMessages(current: Context, parentType: string)/*: SubMessages */ {\n    const pattern = current.pattern;\n    const length = pattern.length;\n    const options: { [key: string]: any } = {};\n    while (current.index < length && pattern[current.index] !== ARG_CLS) {\n        const selector: string = parseId(current);\n        if (!selector) { throw expected(current, 'sub-message selector'); }\n        skipWhitespace(current);\n        const arr = parseSubMessage(current, parentType);\n        options[selector] = arr;\n        skipWhitespace(current);\n    }\n    if (!options['other'] && parentType === 'plural') {\n        throw expected(current, null, null, '\"other\" sub-message must be specified in plural');\n    }\n    return options;\n}\n\nfunction parseSubMessage(current: Context, parentType: string): any[] {\n    if (current.pattern[current.index] !== ARG_OPN) {\n        throw expected(current, ARG_OPN + ' to start sub-message');\n    }\n    ++current.index; // move passed {\n    const message = parseAST(current, parentType);\n    if (current.pattern[current.index] !== ARG_CLS) {\n        throw expected(current, ARG_CLS + ' to end sub-message');\n    }\n    ++current.index; // move passed }\n    return message;\n}\n\nfunction expected(current: Context, expectedstr?: string, found?: string, message?: string): any {\n    const pattern = current.pattern;\n    const lines = pattern.slice(0, current.index).split(/\\r?\\n/);\n    const offset = current.index;\n    const line = lines.length;\n    const column = lines.slice(-1)[0].length;\n    found = found || (\n        (current.index >= pattern.length) ? 'end of message pattern'\n            : (parseId(current) || pattern[current.index])\n    );\n    if (!message) { message = errorMessage(expectedstr, found); }\n    message += ' in ' + pattern.replace(/\\r?\\n/g, '\\n');\n    return new (MessageSyntaxError as any)(message, expectedstr, found, offset, line, column);\n}\n\n// Error function\nfunction errorMessage(expectedstr: string, found: string) {\n    if (!expectedstr) { return 'Unexpected ' + found + ' found'; }\n    return 'Expected ' + expectedstr + ' but found ' + found;\n}\n\n/**\n * SyntaxError\n *  Holds information about bad syntax found in a message pattern\n **/\nfunction MessageSyntaxError(message: string, expectedstr: string, found: string, offset: number, line: number, column: number) {\n    Error.call(this, message);\n    this.name = 'SyntaxError';\n    this.message = message;\n    this.expected = expectedstr;\n    this.found = found;\n    this.offset = offset;\n    this.line = line;\n    this.column = column;\n}\nMessageSyntaxError.prototype = Object.create(Error.prototype);\n"]}