| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162 | diff --git a/src/main.ts b/src/main.tsindex deba4c4..1b41bde 100644--- a/src/main.ts+++ b/src/main.ts@@ -8,2 +8,3 @@ import * as fs from 'original-fs'; import * as os from 'node:os';+import { createRequire } from 'node:module'; import { performance } from 'node:perf_hooks';@@ -22,2 +23,4 @@ import { NativeParsedArgs } from './vs/platform/environment/common/argv.js'; +const require = createRequire(import.meta.url);+ perf.mark('code/didStartMain');@@ -109,2 +112,14 @@ registerListeners(); +function resolveUserProduct() {+	const userProductPath = path.join(userDataPath, 'product.json');++	try {+		// Assign the product configuration to the global scope+		const productJson = require(userProductPath);+		// @ts-expect-error+		globalThis._VSCODE_USER_PRODUCT_JSON = productJson;+	} catch (ex) {+	}+}+ /**@@ -205,2 +220,3 @@ async function startup(codeCachePath: string | undefined, nlsConfig: INLSConfigu 	process.env['VSCODE_CODE_CACHE_PATH'] = codeCachePath || '';+	resolveUserProduct(); diff --git a/src/vs/platform/product/common/product.ts b/src/vs/platform/product/common/product.tsindex 5a6c171..275cbcf 100644--- a/src/vs/platform/product/common/product.ts+++ b/src/vs/platform/product/common/product.ts@@ -31,2 +31,25 @@ else if (globalThis._VSCODE_PRODUCT_JSON && globalThis._VSCODE_PACKAGE_JSON) { +	// Merge user-customized product.json+	try {+		const merge = (...objects: any[]) =>+			objects.reduce((result, current) => {+				Object.keys(current).forEach((key) => {+					if (Array.isArray(result[key]) && Array.isArray(current[key])) {+						result[key] = current[key];+					} else if (typeof result[key] === 'object' && typeof current[key] === 'object') {+						result[key] = merge(result[key], current[key]);+					} else {+						result[key] = current[key];+					}+				});++				return result;+			}, {}) as any;++		const userProduct = (globalThis as Record<string, any>)._VSCODE_USER_PRODUCT_JSON || {};++		product = merge(product, userProduct);+	} catch (ex) {+	}+ 	// Running out of sources
 |