avoid look-behind in nyaize - fixes 419
This commit is contained in:
parent
15665d1533
commit
b02ded29dd
2 changed files with 43 additions and 6 deletions
|
@ -3,21 +3,26 @@
|
||||||
* SPDX-License-Identifier: AGPL-3.0-only
|
* SPDX-License-Identifier: AGPL-3.0-only
|
||||||
*/
|
*/
|
||||||
|
|
||||||
const enRegex1 = /(?<=n)a/gi;
|
|
||||||
const enRegex2 = /(?<=morn)ing/gi;
|
|
||||||
const enRegex3 = /(?<=every)one/gi;
|
|
||||||
const koRegex1 = /[나-낳]/g;
|
const koRegex1 = /[나-낳]/g;
|
||||||
const koRegex2 = /(다$)|(다(?=\.))|(다(?= ))|(다(?=!))|(다(?=\?))/gm;
|
const koRegex2 = /(다$)|(다(?=\.))|(다(?= ))|(다(?=!))|(다(?=\?))/gm;
|
||||||
const koRegex3 = /(야(?=\?))|(야$)|(야(?= ))/gm;
|
const koRegex3 = /(야(?=\?))|(야$)|(야(?= ))/gm;
|
||||||
|
|
||||||
|
function ifAfter(prefix, fn) {
|
||||||
|
const preLen = prefix.length;
|
||||||
|
const regex = new RegExp(prefix,'i');
|
||||||
|
return (x,pos,string) => {
|
||||||
|
return pos > 0 && string.substring(pos-preLen,pos).match(regex) ? fn(x) : x;
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
export function nyaize(text: string): string {
|
export function nyaize(text: string): string {
|
||||||
return text
|
return text
|
||||||
// ja-JP
|
// ja-JP
|
||||||
.replaceAll('な', 'にゃ').replaceAll('ナ', 'ニャ').replaceAll('ナ', 'ニャ')
|
.replaceAll('な', 'にゃ').replaceAll('ナ', 'ニャ').replaceAll('ナ', 'ニャ')
|
||||||
// en-US
|
// en-US
|
||||||
.replace(enRegex1, x => x === 'A' ? 'YA' : 'ya')
|
.replace(/a/gi, ifAfter('n', x => x === 'A' ? 'YA' : 'ya'))
|
||||||
.replace(enRegex2, x => x === 'ING' ? 'YAN' : 'yan')
|
.replace(/ing/gi, ifAfter('morn', x => x === 'ING' ? 'YAN' : 'yan'))
|
||||||
.replace(enRegex3, x => x === 'ONE' ? 'NYAN' : 'nyan')
|
.replace(/one/gi, ifAfter('every', x => x === 'ONE' ? 'NYAN' : 'nyan'))
|
||||||
// ko-KR
|
// ko-KR
|
||||||
.replace(koRegex1, match => String.fromCharCode(
|
.replace(koRegex1, match => String.fromCharCode(
|
||||||
match.charCodeAt(0)! + '냐'.charCodeAt(0) - '나'.charCodeAt(0),
|
match.charCodeAt(0)! + '냐'.charCodeAt(0) - '나'.charCodeAt(0),
|
||||||
|
|
32
packages/frontend/test/nyaize.test.ts
Normal file
32
packages/frontend/test/nyaize.test.ts
Normal file
|
@ -0,0 +1,32 @@
|
||||||
|
import { describe, test, assert, afterEach } from 'vitest';
|
||||||
|
import { nyaize } from '@/scripts/nyaize.js';
|
||||||
|
|
||||||
|
function runTests(cases) {
|
||||||
|
for (const c of cases) {
|
||||||
|
const [input,expected] = c;
|
||||||
|
const got = nyaize(input);
|
||||||
|
assert.strictEqual(got, expected);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
describe('nyaize', () => {
|
||||||
|
test('ja-JP', () => {
|
||||||
|
runTests([
|
||||||
|
['きれいな','きれいにゃ'],
|
||||||
|
['ナナナ', 'ニャニャニャ'],
|
||||||
|
['ナナ','ニャニャ'],
|
||||||
|
]);
|
||||||
|
});
|
||||||
|
test('en-US', () => {
|
||||||
|
runTests([
|
||||||
|
['bar','bar'],
|
||||||
|
['banana','banyanya'],
|
||||||
|
['booting','booting'],
|
||||||
|
['morning','mornyan'],
|
||||||
|
['mmmorning','mmmornyan'],
|
||||||
|
['someone','someone'],
|
||||||
|
['everyone','everynyan'],
|
||||||
|
['foreveryone','foreverynyan'],
|
||||||
|
]);
|
||||||
|
});
|
||||||
|
});
|
Loading…
Reference in a new issue