mirror of
https://gitlab.alpinelinux.org/alpine/aports.git
synced 2025-04-05 04:47:14 +02:00
225 lines
7.6 KiB
Diff
225 lines
7.6 KiB
Diff
From a094a2ca2b6d8758b4aea24389c35fc4f142b715 Mon Sep 17 00:00:00 2001
|
|
From: Fedor Indutny <79877362+indutny-signal@users.noreply.github.com>
|
|
Date: Mon, 3 Mar 2025 19:10:01 -0800
|
|
Subject: [PATCH] Compactify locales even more
|
|
|
|
Rollback of Compactify locales even more. For some reason, (maybe tasje?),
|
|
these new locales aren't working
|
|
|
|
---
|
|
app/locale.ts | 56 ++++++++++++++++--
|
|
package.json | 2 +-
|
|
ts/scripts/generate-compact-locales.ts | 82 +++++++++++++++++++-------
|
|
3 files changed, 112 insertions(+), 28 deletions(-)
|
|
|
|
|
|
diff --git a/Signal-Desktop/package.json.orig b/Signal-Desktop/package.json
|
|
index 04dd9f9200b..e7b69ef963f 100644
|
|
--- a/Signal-Desktop/package.json.orig
|
|
+++ b/Signal-Desktop/package.json
|
|
@@ -538,10 +538,7 @@
|
|
{
|
|
"from": "build/compact-locales",
|
|
"to": "_locales",
|
|
- "filter": [
|
|
- "**/values.json",
|
|
- "keys.json"
|
|
- ]
|
|
+ "filter": "**/messages.json"
|
|
},
|
|
"js/**",
|
|
"libtextsecure/**",
|
|
diff --git a/Signal-Desktop/app/locale.ts.orig b/Signal-Desktop/app/locale.ts
|
|
index a63eef4079d..2a959da4d0d 100644
|
|
--- a/Signal-Desktop/app/locale.ts.orig
|
|
+++ b/Signal-Desktop/app/locale.ts
|
|
@@ -1,9 +1,8 @@
|
|
// Copyright 2017 Signal Messenger, LLC
|
|
// SPDX-License-Identifier: AGPL-3.0-only
|
|
|
|
-import { join } from 'node:path';
|
|
-import { readFileSync } from 'node:fs';
|
|
-import { app } from 'electron';
|
|
+import { join } from 'path';
|
|
+import { readFileSync } from 'fs';
|
|
import { merge } from 'lodash';
|
|
import * as LocaleMatcher from '@formatjs/intl-localematcher';
|
|
import { z } from 'zod';
|
|
@@ -16,9 +15,6 @@ import type { LocalizerType } from '../ts/types/Util';
|
|
import * as Errors from '../ts/types/errors';
|
|
import { parseUnknown } from '../ts/util/schemas';
|
|
|
|
-type CompactLocaleMessagesType = ReadonlyArray<string | null>;
|
|
-type CompactLocaleKeysType = ReadonlyArray<string>;
|
|
-
|
|
const TextInfoSchema = z.object({
|
|
direction: z.enum(['ltr', 'rtl']),
|
|
});
|
|
@@ -29,17 +25,6 @@ function getLocaleMessages(locale: string): LocaleMessagesType {
|
|
return JSON.parse(readFileSync(targetFile, 'utf-8'));
|
|
}
|
|
|
|
-function getCompactLocaleKeys(): CompactLocaleKeysType {
|
|
- const targetFile = join(__dirname, '..', '_locales', 'keys.json');
|
|
- return JSON.parse(readFileSync(targetFile, 'utf-8'));
|
|
-}
|
|
-
|
|
-function getCompactLocaleValues(locale: string): CompactLocaleMessagesType {
|
|
- const targetFile = join(__dirname, '..', '_locales', locale, 'values.json');
|
|
-
|
|
- return JSON.parse(readFileSync(targetFile, 'utf-8'));
|
|
-}
|
|
-
|
|
export type LocaleDisplayNames = Record<string, Record<string, string>>;
|
|
export type CountryDisplayNames = Record<string, Record<string, string>>;
|
|
|
|
@@ -154,42 +139,13 @@ export function load({
|
|
|
|
logger.info(`locale: Matched locale: ${matchedLocale}`);
|
|
|
|
+ const matchedLocaleMessages = getLocaleMessages(matchedLocale);
|
|
+ const englishMessages = getLocaleMessages('en');
|
|
const localeDisplayNames = getLocaleDisplayNames();
|
|
const countryDisplayNames = getCountryDisplayNames();
|
|
|
|
- let finalMessages: LocaleMessagesType;
|
|
- if (app.isPackaged) {
|
|
- const matchedLocaleMessages = getCompactLocaleValues(matchedLocale);
|
|
- const englishMessages = getCompactLocaleValues('en');
|
|
- const keys = getCompactLocaleKeys();
|
|
- if (matchedLocaleMessages.length !== keys.length) {
|
|
- throw new Error(
|
|
- `Invalid "${matchedLocale}" entry count, ` +
|
|
- `${matchedLocaleMessages.length} != ${keys.length}`
|
|
- );
|
|
- }
|
|
- if (englishMessages.length !== keys.length) {
|
|
- throw new Error(
|
|
- `Invalid "en" entry count, ${englishMessages.length} != ${keys.length}`
|
|
- );
|
|
- }
|
|
-
|
|
- // We start with english, then overwrite that with anything present in locale
|
|
- finalMessages = Object.create(null);
|
|
- for (const [i, key] of keys.entries()) {
|
|
- finalMessages[key] = {
|
|
- messageformat:
|
|
- matchedLocaleMessages[i] ?? englishMessages[i] ?? undefined,
|
|
- };
|
|
- }
|
|
- } else {
|
|
- const matchedLocaleMessages = getLocaleMessages(matchedLocale);
|
|
- const englishMessages = getLocaleMessages('en');
|
|
-
|
|
- // We start with english, then overwrite that with anything present in locale
|
|
- finalMessages = merge(englishMessages, matchedLocaleMessages);
|
|
- }
|
|
-
|
|
+ // We start with english, then overwrite that with anything present in locale
|
|
+ const finalMessages = merge(englishMessages, matchedLocaleMessages);
|
|
const i18n = setupI18n(matchedLocale, finalMessages, {
|
|
renderEmojify: shouldNeverBeCalled,
|
|
});
|
|
diff --git a/Signal-Desktop/ts/scripts/generate-compact-locales.ts.orig b/Signal-Desktop/ts/scripts/generate-compact-locales.ts
|
|
index 7187d287acc..9a17d638f44 100644
|
|
--- a/Signal-Desktop/ts/scripts/generate-compact-locales.ts.orig
|
|
+++ b/Signal-Desktop/ts/scripts/generate-compact-locales.ts
|
|
@@ -3,49 +3,6 @@
|
|
|
|
import { readdir, mkdir, readFile, writeFile } from 'node:fs/promises';
|
|
import { join, dirname } from 'node:path';
|
|
-import pMap from 'p-map';
|
|
-import { isLocaleMessageType } from '../util/setupI18nMain';
|
|
-
|
|
-async function compact({
|
|
- sourceDir,
|
|
- targetDir,
|
|
- locale,
|
|
- keys,
|
|
-}: {
|
|
- sourceDir: string;
|
|
- targetDir: string;
|
|
- locale: string;
|
|
- keys: ReadonlyArray<string>;
|
|
-}): Promise<ReadonlyArray<string>> {
|
|
- const sourcePath = join(sourceDir, locale, 'messages.json');
|
|
- const targetPath = join(targetDir, locale, 'values.json');
|
|
-
|
|
- await mkdir(dirname(targetPath), { recursive: true });
|
|
-
|
|
- const json = JSON.parse(await readFile(sourcePath, 'utf8'));
|
|
-
|
|
- const result = new Array<string | null>();
|
|
- for (const key of keys) {
|
|
- if (json[key] == null) {
|
|
- // Pull English translation, or leave blank (string was deleted)
|
|
- result.push(null);
|
|
- continue;
|
|
- }
|
|
-
|
|
- const value = json[key];
|
|
- if (!isLocaleMessageType(value)) {
|
|
- continue;
|
|
- }
|
|
- if (value.messageformat == null) {
|
|
- continue;
|
|
- }
|
|
- result.push(value.messageformat);
|
|
- }
|
|
-
|
|
- await writeFile(targetPath, JSON.stringify(result));
|
|
-
|
|
- return keys;
|
|
-}
|
|
|
|
async function main(): Promise<void> {
|
|
const rootDir = join(__dirname, '..', '..');
|
|
@@ -54,27 +11,30 @@ async function main(): Promise<void> {
|
|
|
|
const locales = await readdir(sourceDir);
|
|
|
|
- const allKeys = await pMap(
|
|
- locales,
|
|
- async locale => {
|
|
+ await Promise.all(
|
|
+ locales.map(async locale => {
|
|
const sourcePath = join(sourceDir, locale, 'messages.json');
|
|
- const json = JSON.parse(await readFile(sourcePath, 'utf8'));
|
|
- return Object.entries(json)
|
|
- .filter(([, value]) => isLocaleMessageType(value))
|
|
- .map(([key]) => key);
|
|
- },
|
|
- { concurrency: 10 }
|
|
- );
|
|
+ const targetPath = join(targetDir, locale, 'messages.json');
|
|
|
|
- // Sort keys alphabetically for better incremental updates.
|
|
- const keys = Array.from(new Set(allKeys.flat())).sort();
|
|
- await mkdir(targetDir, { recursive: true });
|
|
- await writeFile(join(targetDir, 'keys.json'), JSON.stringify(keys));
|
|
+ await mkdir(dirname(targetPath), { recursive: true });
|
|
|
|
- await pMap(
|
|
- locales,
|
|
- locale => compact({ sourceDir, targetDir, locale, keys }),
|
|
- { concurrency: 10 }
|
|
+ const json = JSON.parse(await readFile(sourcePath, 'utf8'));
|
|
+ for (const value of Object.values(json)) {
|
|
+ const typedValue = value as { description?: string };
|
|
+ delete typedValue.description;
|
|
+ }
|
|
+ delete json.smartling;
|
|
+
|
|
+ const entries = [...Object.entries(json)];
|
|
+
|
|
+ // Sort entries alphabetically for better incremental updates.
|
|
+ entries.sort(([a], [b]) => {
|
|
+ return a < b ? -1 : 1;
|
|
+ });
|
|
+
|
|
+ const result = Object.fromEntries(entries);
|
|
+ await writeFile(targetPath, JSON.stringify(result));
|
|
+ })
|
|
);
|
|
}
|
|
|