//@ts-check 'use strict'; const path = require('path'); const glob = require('glob'); module.exports = (env, argv) => { let entry = { 'extension': './src/extension.ts', 'server': './node_modules/fabric8-analytics-lsp-server/dist/server.js', }; // debug if (argv.mode !== 'production') { /* entry['test/all.test'] = glob.sync('./test/*.test.ts'); */ } /**@type {import('webpack').Configuration}*/ const config = { target: 'node', // vscode extensions run in a Node.js-context 📖 -> https://webpack.js.org/configuration/node/ entry: entry, // the entry point of this extension, 📖 -> https://webpack.js.org/configuration/entry-context/ output: { // the bundle is stored in the 'out' folder (check package.json), 📖 -> https://webpack.js.org/configuration/output/ path: path.resolve(__dirname, 'dist'), filename: '[name].js', libraryTarget: 'commonjs2', devtoolModuleFilenameTemplate: '../[resource-path]' }, devtool: 'source-map', externals: { vscode: 'commonjs vscode' // the vscode-module is created on-the-fly and must be excluded. Add other modules that cannot be webpack'ed, 📖 -> https://webpack.js.org/configuration/externals/ }, resolve: { // support reading TypeScript and JavaScript files, 📖 -> https://github.com/TypeStrong/ts-loader extensions: ['.ts', '.js'] }, module: { rules: [{ test: /\.js$/, enforce: 'pre', use: ['source-map-loader'], }, { test: /\.ts$/, exclude: /node_modules/, use: [{ loader: 'ts-loader', options: { compilerOptions: { "module": "es6" // override `tsconfig.json` so that TypeScript emits native JavaScript modules. } } }] }] }, }; return config; };