vscode/extensions/shared.webpack.config.js

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

210 lines
7 KiB
JavaScript
Raw Normal View History

2018-08-17 13:56:57 +00:00
/*---------------------------------------------------------------------------------------------
* Copyright (c) Microsoft Corporation. All rights reserved.
* Licensed under the MIT License. See License.txt in the project root for license information.
*--------------------------------------------------------------------------------------------*/
//@ts-check
/** @typedef {import('webpack').Configuration} WebpackConfig **/
2018-08-17 13:56:57 +00:00
'use strict';
const path = require('path');
const fs = require('fs');
2018-08-20 13:23:56 +00:00
const merge = require('merge-options');
const CopyWebpackPlugin = require('copy-webpack-plugin');
const { NLSBundlePlugin } = require('vscode-nls-dev/lib/webpack-bundler');
const { DefinePlugin, optimize } = require('webpack');
const tsLoaderOptions = {
compilerOptions: {
'sourceMap': true,
},
onlyCompileBundledFiles: true,
};
function withNodeDefaults(/**@type WebpackConfig & { context: string }*/extConfig) {
2022-06-08 15:49:21 +00:00
const defaultConfig = {
2018-08-17 13:56:57 +00:00
mode: 'none', // this leaves the source code as close as possible to the original (when packaging we set this to 'production')
target: 'node', // extensions run in a node context
node: {
__dirname: false // leave the __dirname-behaviour intact
},
2018-08-17 13:56:57 +00:00
resolve: {
conditionNames: ['import', 'require', 'node-addons', 'node'],
mainFields: ['module', 'main'],
2018-08-20 10:18:30 +00:00
extensions: ['.ts', '.js'] // support ts-files and js-files
2018-08-17 13:56:57 +00:00
},
module: {
2018-08-20 10:18:30 +00:00
rules: [{
test: /\.ts$/,
exclude: /node_modules/,
use: [{
// vscode-nls-dev loader:
// * rewrite nls-calls
loader: 'vscode-nls-dev/lib/webpack-loader',
options: {
base: path.join(extConfig.context, 'src')
}
2018-08-20 10:18:30 +00:00
}, {
// configure TypeScript loader:
// * enable sources maps for end-to-end source maps
loader: 'ts-loader',
options: tsLoaderOptions
}, {
loader: path.resolve(__dirname, 'mangle-loader.js'),
options: {
configFile: path.join(extConfig.context, 'tsconfig.json')
},
},]
2018-08-20 10:18:30 +00:00
}]
2018-08-17 13:56:57 +00:00
},
2018-08-20 13:23:56 +00:00
externals: {
'vscode': 'commonjs vscode', // ignored because it doesn't exist,
'applicationinsights-native-metrics': 'commonjs applicationinsights-native-metrics', // ignored because we don't ship native module
'@azure/functions-core': 'commonjs azure/functions-core', // optioinal dependency of appinsights that we don't use
'@opentelemetry/tracing': 'commonjs @opentelemetry/tracing', // ignored because we don't ship this module
'@opentelemetry/instrumentation': 'commonjs @opentelemetry/instrumentation', // ignored because we don't ship this module
'@azure/opentelemetry-instrumentation-azure-sdk': 'commonjs @azure/opentelemetry-instrumentation-azure-sdk', // ignored because we don't ship this module
2018-08-20 13:23:56 +00:00
},
2018-08-17 13:56:57 +00:00
output: {
// all output goes into `dist`.
// packaging depends on that and this must always be like it
filename: '[name].js',
2018-08-20 13:23:56 +00:00
path: path.join(extConfig.context, 'dist'),
2019-12-31 08:53:57 +00:00
libraryTarget: 'commonjs',
2018-08-17 13:56:57 +00:00
},
// yes, really source maps
devtool: 'source-map',
2021-07-09 09:55:21 +00:00
plugins: nodePlugins(extConfig.context),
2018-08-21 08:27:03 +00:00
};
2018-08-20 13:23:56 +00:00
return merge(defaultConfig, extConfig);
2020-07-21 05:46:09 +00:00
}
2020-06-25 21:21:56 +00:00
/**
*
* @param {string} context
*/
2021-07-09 09:55:21 +00:00
function nodePlugins(context) {
2021-07-08 19:41:03 +00:00
// Need to find the top-most `package.json` file
const folderName = path.relative(__dirname, context).split(/[\\\/]/)[0];
const pkgPath = path.join(__dirname, folderName, 'package.json');
const pkg = JSON.parse(fs.readFileSync(pkgPath, 'utf8'));
const id = `${pkg.publisher}.${pkg.name}`;
return [
new CopyWebpackPlugin({
patterns: [
{ from: 'src', to: '.', globOptions: { ignore: ['**/test/**', '**/*.ts'] }, noErrorOnMissing: true }
]
}),
new NLSBundlePlugin(id)
];
}
/**
* @typedef {{
* configFile?: string
* }} AdditionalBrowserConfig
*/
2021-07-08 19:41:03 +00:00
function withBrowserDefaults(/**@type WebpackConfig & { context: string }*/extConfig, /** @type AdditionalBrowserConfig */ additionalOptions = {}) {
2020-06-25 21:21:56 +00:00
/** @type WebpackConfig */
2022-06-08 15:49:21 +00:00
const defaultConfig = {
2020-06-25 21:21:56 +00:00
mode: 'none', // this leaves the source code as close as possible to the original (when packaging we set this to 'production')
target: 'webworker', // extensions run in a webworker context
resolve: {
2021-07-26 17:44:43 +00:00
mainFields: ['browser', 'module', 'main'],
2020-06-25 21:21:56 +00:00
extensions: ['.ts', '.js'], // support ts-files and js-files
2021-07-08 19:41:03 +00:00
fallback: {
'path': require.resolve('path-browserify'),
'util': require.resolve('util')
2020-06-25 21:21:56 +00:00
}
},
module: {
rules: [{
test: /\.ts$/,
exclude: /node_modules/,
use: [
{
// configure TypeScript loader:
// * enable sources maps for end-to-end source maps
loader: 'ts-loader',
options: {
...tsLoaderOptions,
...(additionalOptions ? {} : { configFile: additionalOptions.configFile }),
}
},
{
loader: path.resolve(__dirname, 'mangle-loader.js'),
options: {
configFile: path.join(extConfig.context, additionalOptions?.configFile ?? 'tsconfig.json')
},
},
]
}, {
test: /\.wasm$/,
type: 'asset/inline'
2020-06-25 21:21:56 +00:00
}]
},
externals: {
'vscode': 'commonjs vscode', // ignored because it doesn't exist,
'applicationinsights-native-metrics': 'commonjs applicationinsights-native-metrics', // ignored because we don't ship native module
'@azure/functions-core': 'commonjs azure/functions-core', // optioinal dependency of appinsights that we don't use
'@opentelemetry/tracing': 'commonjs @opentelemetry/tracing', // ignored because we don't ship this module
'@opentelemetry/instrumentation': 'commonjs @opentelemetry/instrumentation', // ignored because we don't ship this module
'@azure/opentelemetry-instrumentation-azure-sdk': 'commonjs @azure/opentelemetry-instrumentation-azure-sdk', // ignored because we don't ship this module
2020-06-25 21:21:56 +00:00
},
performance: {
hints: false
},
output: {
// all output goes into `dist`.
// packaging depends on that and this must always be like it
filename: '[name].js',
path: path.join(extConfig.context, 'dist', 'browser'),
libraryTarget: 'commonjs',
},
// yes, really source maps
devtool: 'source-map',
plugins: browserPlugins(extConfig.context)
2020-06-25 21:21:56 +00:00
};
return merge(defaultConfig, extConfig);
2020-07-21 05:46:09 +00:00
}
2020-06-25 21:21:56 +00:00
/**
*
* @param {string} context
*/
function browserPlugins(context) {
// Need to find the top-most `package.json` file
// const folderName = path.relative(__dirname, context).split(/[\\\/]/)[0];
// const pkgPath = path.join(__dirname, folderName, 'package.json');
// const pkg = JSON.parse(fs.readFileSync(pkgPath, 'utf8'));
// const id = `${pkg.publisher}.${pkg.name}`;
return [
new optimize.LimitChunkCountPlugin({
maxChunks: 1
}),
new CopyWebpackPlugin({
patterns: [
{ from: 'src', to: '.', globOptions: { ignore: ['**/test/**', '**/*.ts'] }, noErrorOnMissing: true }
]
}),
new DefinePlugin({
'process.platform': JSON.stringify('web'),
'process.env': JSON.stringify({}),
'process.env.BROWSER_ENV': JSON.stringify('true')
}),
// TODO: bring this back once vscode-nls-dev supports browser
// new NLSBundlePlugin(id)
];
}
2020-06-25 21:21:56 +00:00
module.exports = withNodeDefaults;
module.exports.node = withNodeDefaults;
module.exports.browser = withBrowserDefaults;
2021-07-09 09:55:21 +00:00
module.exports.nodePlugins = nodePlugins;
module.exports.browserPlugins = browserPlugins;
2020-06-25 21:21:56 +00:00