4a80bcb42c
* Add trace log level * Use active eval to implement spdlog * Split server/client active eval interfaces Since all properties are *not* valid on both sides * +200% fire resistance * Implement exec using active evaluations * Fully implement child process streams * Watch impl, move child_process back to explicitly adding events Automatically forwarding all events might be the right move, but wanna think/discuss it a bit more because it didn't come out very cleanly. * Would you like some args with that callback? * Implement the rest of child_process using active evals * Rampant memory leaks Emit "kill" to active evaluations when client disconnects in order to kill processes. Most likely won't be the final solution. * Resolve some minor issues with output panel * Implement node-pty with active evals * Provide clearTimeout to vm sandbox * Implement socket with active evals * Extract some callback logic Also remove some eval interfaces, need to re-think those. * Implement net.Server and remainder of net.Socket using active evals * Implement dispose for active evaluations * Use trace for express requests * Handle sending buffers through evaluation events * Make event logging a bit more clear * Fix some errors due to us not actually instantiating until connect/listen * is this a commit message? * We can just create the evaluator in the ctor Not sure what I was thinking. * memory leak for you, memory leak for everyone * it's a ternary now * Don't dispose automatically on close or error The code may or may not be disposable at that point. * Handle parsing buffers on the client side as well * Remove unused protobuf * Remove TypedValue * Remove unused forkProvider and test * Improve dispose pattern for active evals * Socket calls close after error; no need to bind both * Improve comment * Comment is no longer wishy washy due to explicit boolean * Simplify check for sendHandle and options * Replace _require with __non_webpack_require__ Webpack will then replace this with `require` which we then provide to the vm sandbox. * Provide path.parse * Prevent original-fs from loading * Start with a pid of -1 vscode immediately checks the PID to see if the debug process launch correctly, but of course we don't get the pid synchronously. * Pass arguments to bootstrap-fork * Fully implement streams Was causing errors because internally the stream would set this.writing to true and it would never become false, so subsequent messages would never send. * Fix serializing errors and streams emitting errors multiple times * Was emitting close to data * Fix missing path for spawned processes * Move evaluation onDispose call Now it's accurate and runs when the active evaluation has actually disposed. * Fix promisifying fs.exists * Fix some active eval callback issues * Patch existsSync in debug adapter
92 lines
3.1 KiB
JavaScript
92 lines
3.1 KiB
JavaScript
const path = require("path");
|
|
const HtmlWebpackPlugin = require("html-webpack-plugin");
|
|
const { BundleAnalyzerPlugin } = require("webpack-bundle-analyzer");
|
|
const PreloadWebpackPlugin = require("preload-webpack-plugin");
|
|
const root = path.resolve(__dirname, "../..");
|
|
const fills = path.join(root, "packages/ide/src/fill");
|
|
const vsFills = path.join(root, "packages/vscode/src/fill");
|
|
|
|
const merge = require("webpack-merge");
|
|
|
|
module.exports = merge({
|
|
entry: "./packages/web/src/index.ts",
|
|
output: {
|
|
chunkFilename: "[name]-[hash:6].bundle.js",
|
|
path: path.join(root, "dist"),
|
|
filename: "[hash:6].bundle.js",
|
|
},
|
|
node: {
|
|
module: "empty",
|
|
crypto: "empty",
|
|
tls: "empty",
|
|
},
|
|
resolve: {
|
|
alias: {
|
|
"gc-signals": path.join(fills, "empty.ts"),
|
|
"selenium-webdriver": path.join(fills, "empty.ts"),
|
|
"vscode": path.join(fills, "empty.ts"),
|
|
"vscode-fsevents": path.join(fills, "empty.ts"),
|
|
"vsda": path.join(fills, "empty.ts"),
|
|
"windows-foreground-love": path.join(fills, "empty.ts"),
|
|
"windows-mutex": path.join(fills, "empty.ts"),
|
|
"windows-process-tree": path.join(fills, "empty.ts"),
|
|
"vscode-sqlite3": path.join(fills, "empty.ts"),
|
|
"tls": path.join(fills, "empty.ts"),
|
|
"native-is-elevated": path.join(fills, "empty.ts"),
|
|
"dns": path.join(fills, "empty.ts"),
|
|
"console": path.join(fills, "empty.ts"),
|
|
"readline": path.join(fills, "empty.ts"),
|
|
"oniguruma": path.join(fills, "empty.ts"),
|
|
|
|
// Webpack includes path-browserify but not the latest version, so
|
|
// path.posix and path.parse are undefined (among other things possibly).
|
|
// Also if we don't provide the full path, the code in vscode will import
|
|
// from vscode's node_modules which is the wrong version.
|
|
"path": path.join(root, "node_modules", "path-browserify"),
|
|
"crypto": "crypto-browserify",
|
|
"http": "http-browserify",
|
|
|
|
"child_process": path.join(fills, "child_process.ts"),
|
|
"os": path.join(fills, "os.ts"),
|
|
"fs": path.join(fills, "fs.ts"),
|
|
"net": path.join(fills, "net.ts"),
|
|
"util": path.join(fills, "util.ts"),
|
|
"electron": path.join(fills, "electron.ts"),
|
|
|
|
"native-keymap": path.join(vsFills, "native-keymap.ts"),
|
|
"node-pty": path.join(vsFills, "node-pty.ts"),
|
|
"graceful-fs": path.join(vsFills, "graceful-fs.ts"),
|
|
"spdlog": path.join(vsFills, "spdlog.ts"),
|
|
"native-watchdog": path.join(vsFills, "native-watchdog.ts"),
|
|
"iconv-lite": path.join(vsFills, "iconv-lite.ts"),
|
|
|
|
"vs/base/node/paths": path.join(vsFills, "paths.ts"),
|
|
"vs/base/common/amd": path.join(vsFills, "amd.ts"),
|
|
"vs/platform/node/product": path.join(vsFills, "product.ts"),
|
|
"vs/platform/node/package": path.join(vsFills, "package.ts"),
|
|
"vs": path.join(root, "lib", "vscode", "src", "vs"),
|
|
},
|
|
},
|
|
resolveLoader: {
|
|
alias: {
|
|
"vs/css": path.join(vsFills, "css.js"),
|
|
},
|
|
},
|
|
plugins: [
|
|
new HtmlWebpackPlugin({
|
|
template: "packages/web/src/index.html",
|
|
}),
|
|
new PreloadWebpackPlugin({
|
|
rel: "preload",
|
|
as: "script",
|
|
}),
|
|
],
|
|
target: "web",
|
|
}, require(path.join(root, "scripts", "webpack.general.config.js"))({
|
|
typescriptCompilerOptions: {
|
|
"target": "es5",
|
|
"lib": ["dom", "esnext"],
|
|
"importHelpers": true,
|
|
},
|
|
}));
|