aports/testing/signal-desktop/signal-rollback-locale-changes.patch
2025-03-28 06:31:49 +00:00

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));
+ })
);
}