refactor: const Module = require('module') as NodeJS.ModuleInternal; (#38757)

Co-authored-by: Milan Burda <miburda@microsoft.com>
This commit is contained in:
Milan Burda 2023-09-07 00:04:25 +02:00 committed by GitHub
parent 65901f4c6a
commit e71a56d11e
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
8 changed files with 20 additions and 9 deletions

View file

@ -5,7 +5,7 @@ import type * as Crypto from 'crypto';
const asar = process._linkedBinding('electron_common_asar'); const asar = process._linkedBinding('electron_common_asar');
const Module = require('module'); const Module = require('module') as NodeJS.ModuleInternal;
const Promise: PromiseConstructor = global.Promise; const Promise: PromiseConstructor = global.Promise;

View file

@ -4,7 +4,7 @@ import * as path from 'path';
import type * as defaultMenuModule from '@electron/internal/browser/default-menu'; import type * as defaultMenuModule from '@electron/internal/browser/default-menu';
const Module = require('module'); const Module = require('module') as NodeJS.ModuleInternal;
// We modified the original process.argv to let node.js load the init.js, // We modified the original process.argv to let node.js load the init.js,
// we need to restore it here. // we need to restore it here.

View file

@ -1,6 +1,6 @@
import * as path from 'path'; import * as path from 'path';
const Module = require('module'); const Module = require('module') as NodeJS.ModuleInternal;
// We do not want to allow use of the VM module in the renderer process as // We do not want to allow use of the VM module in the renderer process as
// it conflicts with Blink's V8::Context internal logic. // it conflicts with Blink's V8::Context internal logic.
@ -10,7 +10,7 @@ if (process.type === 'renderer') {
if (request === 'vm') { if (request === 'vm') {
console.warn('The vm module of Node.js is deprecated in the renderer process and will be removed.'); console.warn('The vm module of Node.js is deprecated in the renderer process and will be removed.');
} }
return _load.apply(this, arguments); return _load.apply(this, arguments as any);
}; };
} }
@ -60,7 +60,7 @@ const originalResolveFilename = Module._resolveFilename;
// renderer process regardless of the names, they're superficial for TypeScript // renderer process regardless of the names, they're superficial for TypeScript
// only. // only.
const electronModuleNames = new Set(['electron', 'electron/main', 'electron/renderer', 'electron/common']); const electronModuleNames = new Set(['electron', 'electron/main', 'electron/renderer', 'electron/common']);
Module._resolveFilename = function (request: string, parent: NodeModule, isMain: boolean, options?: { paths: Array<string>}) { Module._resolveFilename = function (request, parent, isMain, options) {
if (electronModuleNames.has(request)) { if (electronModuleNames.has(request)) {
return 'electron'; return 'electron';
} else { } else {

View file

@ -5,7 +5,7 @@ import { IPC_MESSAGES } from '@electron/internal/common/ipc-messages';
import type * as ipcRendererInternalModule from '@electron/internal/renderer/ipc-renderer-internal'; import type * as ipcRendererInternalModule from '@electron/internal/renderer/ipc-renderer-internal';
import type * as ipcRendererUtilsModule from '@electron/internal/renderer/ipc-renderer-internal-utils'; import type * as ipcRendererUtilsModule from '@electron/internal/renderer/ipc-renderer-internal-utils';
const Module = require('module'); const Module = require('module') as NodeJS.ModuleInternal;
// Make sure globals like "process" and "global" are always available in preload // Make sure globals like "process" and "global" are always available in preload
// scripts even after they are deleted in "loaded" script. // scripts even after they are deleted in "loaded" script.

View file

@ -1,5 +1,5 @@
import { ParentPort } from '@electron/internal/utility/parent-port'; import { ParentPort } from '@electron/internal/utility/parent-port';
const Module = require('module'); const Module = require('module') as NodeJS.ModuleInternal;
const v8Util = process._linkedBinding('electron_common_v8_util'); const v8Util = process._linkedBinding('electron_common_v8_util');
const entryScript: string = v8Util.getHiddenValue(process, '_serviceStartupScript'); const entryScript: string = v8Util.getHiddenValue(process, '_serviceStartupScript');

View file

@ -1,6 +1,6 @@
import * as path from 'path'; import * as path from 'path';
const Module = require('module'); const Module = require('module') as NodeJS.ModuleInternal;
// We modified the original process.argv to let node.js load the // We modified the original process.argv to let node.js load the
// init.js, we need to restore it here. // init.js, we need to restore it here.

View file

@ -7,7 +7,7 @@ import { closeAllWindows } from './lib/window-helpers';
import * as childProcess from 'node:child_process'; import * as childProcess from 'node:child_process';
import { once } from 'node:events'; import { once } from 'node:events';
const Module = require('node:module'); const Module = require('node:module') as NodeJS.ModuleInternal;
const nativeModulesEnabled = !process.env.ELECTRON_SKIP_NATIVE_MODULE_TESTS; const nativeModulesEnabled = !process.env.ELECTRON_SKIP_NATIVE_MODULE_TESTS;

View file

@ -3,6 +3,17 @@ declare const BUILDFLAG: (flag: boolean) => boolean;
declare const ENABLE_VIEWS_API: boolean; declare const ENABLE_VIEWS_API: boolean;
declare namespace NodeJS { declare namespace NodeJS {
interface ModuleInternal extends NodeJS.Module {
new(id: string, parent?: NodeJS.Module | null): NodeJS.Module;
_load(request: string, parent?: NodeJS.Module | null, isMain?: boolean): any;
_resolveFilename(request: string, parent?: NodeJS.Module | null, isMain?: boolean, options?: { paths: string[] }): string;
_preloadModules(requests: string[]): void;
_nodeModulePaths(from: string): string[];
_extensions: Record<string, (module: NodeJS.Module, filename: string) => any>;
_cache: Record<string, NodeJS.Module>;
wrapper: [string, string];
}
interface FeaturesBinding { interface FeaturesBinding {
isBuiltinSpellCheckerEnabled(): boolean; isBuiltinSpellCheckerEnabled(): boolean;
isPDFViewerEnabled(): boolean; isPDFViewerEnabled(): boolean;