da0fd286b4
* chore: initial scaffolding * chore: implement interface and docs * chore: address code style review * fix: cleanup of utility process on shutdown * chore: simplify NodeBindings::CreateEnvironment * chore: rename disableLibraryValidation => allowLoadingUnsignedLibraries * chore: implement process.parentPort * chore(posix): implement stdio pipe interface * chore(win): implement stdio interface * chore: reenable SetNodeOptions for utility process * chore: add specs * chore: fix lint * fix: update kill API * fix: update process.parentPort API * fix: exit event * docs: update exit event * fix: tests on linux * chore: expand on some comments * fix: shutdown of pipe reader Avoid logging since it is always the case that reader end of pipe will terminate after the child process. * fix: remove exit code check for crash spec * fix: rm PR_SET_NO_NEW_PRIVS for unsandbox utility process * chore: fix incorrect rebase * fix: address review feedback * chore: rename utility_process -> utility * chore: update docs * chore: cleanup c++ implemantation * fix: leak in NodeServiceHost impl * chore: minor cleanup * chore: cleanup JS implementation * chore: flip default stdio to inherit * fix: some api improvements * Support cwd option * Remove path restriction for modulePath * Rewire impl for env support * fix: add tests for cwd and env option * chore: alt impl for reading stdio handles * chore: support message queuing * chore: fix lint * chore: new UtilityProcess => utilityProcess.fork * fix: support for uncaught exception exits * chore: remove process.execArgv as default * fix: windows build * fix: style changes * fix: docs and style changes * chore: update patches * spec: disable flaky test on win32 arm CI Co-authored-by: PatchUp <73610968+patchup[bot]@users.noreply.github.com>
116 lines
3.4 KiB
TypeScript
116 lines
3.4 KiB
TypeScript
import * as cp from 'child_process';
|
|
import * as fs from 'fs-extra';
|
|
import * as os from 'os';
|
|
import * as path from 'path';
|
|
|
|
const rootPath = path.resolve(__dirname, '..');
|
|
const gniPath = path.resolve(__dirname, '../filenames.auto.gni');
|
|
|
|
const allDocs = fs.readdirSync(path.resolve(__dirname, '../docs/api'))
|
|
.map(doc => `docs/api/${doc}`)
|
|
.concat(
|
|
fs.readdirSync(path.resolve(__dirname, '../docs/api/structures'))
|
|
.map(doc => `docs/api/structures/${doc}`)
|
|
);
|
|
|
|
const typingFiles = fs.readdirSync(path.resolve(__dirname, '../typings')).map(child => `typings/${child}`);
|
|
|
|
const main = async () => {
|
|
const webpackTargets = [
|
|
{
|
|
name: 'sandbox_bundle_deps',
|
|
config: 'webpack.config.sandboxed_renderer.js'
|
|
},
|
|
{
|
|
name: 'isolated_bundle_deps',
|
|
config: 'webpack.config.isolated_renderer.js'
|
|
},
|
|
{
|
|
name: 'browser_bundle_deps',
|
|
config: 'webpack.config.browser.js'
|
|
},
|
|
{
|
|
name: 'renderer_bundle_deps',
|
|
config: 'webpack.config.renderer.js'
|
|
},
|
|
{
|
|
name: 'worker_bundle_deps',
|
|
config: 'webpack.config.worker.js'
|
|
},
|
|
{
|
|
name: 'asar_bundle_deps',
|
|
config: 'webpack.config.asar.js'
|
|
},
|
|
{
|
|
name: 'utility_bundle_deps',
|
|
config: 'webpack.config.utility.js'
|
|
}
|
|
];
|
|
|
|
const webpackTargetsWithDeps = await Promise.all(webpackTargets.map(async webpackTarget => {
|
|
const tmpDir = await fs.mkdtemp(path.resolve(os.tmpdir(), 'electron-filenames-'));
|
|
const child = cp.spawn('node', [
|
|
'./node_modules/webpack-cli/bin/cli.js',
|
|
'--config', `./build/webpack/${webpackTarget.config}`,
|
|
'--stats', 'errors-only',
|
|
'--output-path', tmpDir,
|
|
'--output-filename', `${webpackTarget.name}.measure.js`,
|
|
'--env', 'PRINT_WEBPACK_GRAPH'
|
|
], {
|
|
cwd: path.resolve(__dirname, '..')
|
|
});
|
|
let output = '';
|
|
child.stdout.on('data', chunk => {
|
|
output += chunk.toString();
|
|
});
|
|
child.stderr.on('data', chunk => console.error(chunk.toString()));
|
|
await new Promise<void>((resolve, reject) => child.on('exit', (code) => {
|
|
if (code !== 0) {
|
|
console.error(output);
|
|
return reject(new Error(`Failed to list webpack dependencies for entry: ${webpackTarget.name}`));
|
|
}
|
|
|
|
resolve();
|
|
}));
|
|
|
|
const webpackTargetWithDeps = {
|
|
...webpackTarget,
|
|
dependencies: (JSON.parse(output) as string[])
|
|
// Remove whitespace
|
|
.map(line => line.trim())
|
|
// Get the relative path
|
|
.map(line => path.relative(rootPath, line).replace(/\\/g, '/'))
|
|
// Only care about files in //electron
|
|
.filter(line => !line.startsWith('..'))
|
|
// Only care about our own files
|
|
.filter(line => !line.startsWith('node_modules'))
|
|
// All webpack builds depend on the tsconfig and package json files
|
|
.concat(['tsconfig.json', 'tsconfig.electron.json', 'package.json', ...typingFiles])
|
|
// Make the generated list easier to read
|
|
.sort()
|
|
};
|
|
await fs.remove(tmpDir);
|
|
return webpackTargetWithDeps;
|
|
}));
|
|
|
|
fs.writeFileSync(
|
|
gniPath,
|
|
`# THIS FILE IS AUTO-GENERATED, PLEASE DO NOT EDIT BY HAND
|
|
auto_filenames = {
|
|
api_docs = [
|
|
${allDocs.map(doc => ` "${doc}",`).join('\n')}
|
|
]
|
|
|
|
${webpackTargetsWithDeps.map(target => ` ${target.name} = [
|
|
${target.dependencies.map(dep => ` "${dep}",`).join('\n')}
|
|
]`).join('\n\n')}
|
|
}
|
|
`);
|
|
};
|
|
|
|
if (require.main === module) {
|
|
main().catch((err) => {
|
|
console.error(err);
|
|
process.exit(1);
|
|
});
|
|
}
|