c6d35d098a
* Implement net.Server * Move Socket class into Client This way we don't need to expose anything. * Remove some unused imports * Pass environment variables to bootstrap fork * Add debug log for when socket disconnects from server * Use VSCODE_ALLOW_IO for shared process only * Extension host can send messages now * Support callback for logging This lets us do potentially expensive operations which will only be performed if the log level is sufficiently low. * Stop extension host from committing suicide * Blank line * Add static serve (#21) * Add extension URLs * how did i remove this * Fix writing an empty string * Implement dialogs on window service
82 lines
2.5 KiB
JavaScript
82 lines
2.5 KiB
JavaScript
const path = require("path");
|
|
const webpack = require("webpack");
|
|
|
|
const root = path.resolve(__dirname, "../..");
|
|
const fills = path.join(root, "packages/ide/src/fill");
|
|
const vscodeFills = path.join(root, "packages/vscode/src/fill");
|
|
|
|
const merge = require("webpack-merge");
|
|
|
|
module.exports = (env) => {
|
|
return merge(require(path.join(root, "scripts/webpack.general.config.js"))({
|
|
typescriptCompilerOptions: {
|
|
target: "es5",
|
|
},
|
|
}), {
|
|
entry: path.join(root, "lib/vscode/src/bootstrap-fork.js"),
|
|
mode: "development",
|
|
target: "node",
|
|
externals: ["node-pty", "spdlog"],
|
|
output: {
|
|
chunkFilename: "[name].bundle.js",
|
|
path: path.resolve(__dirname, "./bin"),
|
|
publicPath: "/",
|
|
filename: "bootstrap-fork.js",
|
|
libraryTarget: "commonjs",
|
|
globalObject: "this",
|
|
},
|
|
module: {
|
|
rules: [{
|
|
loader: "string-replace-loader",
|
|
test: /\.(js|ts)$/,
|
|
options: {
|
|
multiple: [
|
|
{
|
|
search: "require\\.toUrl\\(",
|
|
replace: "requireToUrl(",
|
|
flags: "g",
|
|
},
|
|
{
|
|
search: "require\\.__\\$__nodeRequire",
|
|
replace: "require",
|
|
flags: "g",
|
|
},
|
|
],
|
|
},
|
|
}, {
|
|
test: /\.wasm$/,
|
|
type: "javascript/auto",
|
|
}, {
|
|
// Ignore a bunch of file types we don't have loaders for. Also ignore
|
|
// test directories, some files with invalid JSON, and files we don't
|
|
// actually require but throw warnings or errors. This all seems to be a
|
|
// case of dynamic loading including things we won't require.
|
|
// This also results in the bundle being significantly smaller which
|
|
// makes uglify much faster.
|
|
test: /(\/vs\/code\/electron-main\/)|(\/test\/)|(OSSREADME\.json$)|(\.(test\.ts|test\.js|d\.ts|qwoff|node|html|txt|exe|wuff|md|sh|scpt|less)$)/,
|
|
use: ["ignore-loader"]
|
|
}],
|
|
},
|
|
resolve: {
|
|
alias: {
|
|
"gc-signals": path.join(fills, "empty.ts"),
|
|
"native-keymap": path.join(fills, "native-keymap.ts"),
|
|
"windows-process-tree": path.resolve(fills, "empty.ts"),
|
|
|
|
"electron": path.join(vscodeFills, "stdioElectron.ts"),
|
|
"native-watchdog": path.join(vscodeFills, "native-watchdog.ts"),
|
|
"vs/platform/node/product": path.resolve(vscodeFills, "product.ts"),
|
|
"vs/platform/node/package": path.resolve(vscodeFills, "package.ts"),
|
|
"vs/base/node/paths": path.resolve(vscodeFills, "paths.ts"),
|
|
"vs/base/common/amd": path.resolve(vscodeFills, "amd.ts"),
|
|
"vs": path.resolve(root, "lib/vscode/src/vs"),
|
|
},
|
|
},
|
|
resolveLoader: {
|
|
alias: {
|
|
"vs/css": path.resolve(vscodeFills, "css.js"),
|
|
},
|
|
},
|
|
});
|
|
};
|