提交 01365dbe 编写于 作者: J Johannes Rieken

webpack - more defaults for extensions

上级 7b5dc58b
...@@ -5,14 +5,14 @@ ...@@ -5,14 +5,14 @@
'use strict'; 'use strict';
const sharedConfig = require('../shared.webpack.config'); const withDefaults = require('../shared.webpack.config');
const myConfig = { const myConfig = {
context: __dirname,
entry: { entry: {
extension: './src/extension.ts', extension: './src/extension.ts',
}, },
externals: { externals: {
'vscode': 'commonjs vscode', // ignored because it doesn't exist
'@emmetio/css-parser': 'commonjs @emmetio/css-parser', '@emmetio/css-parser': 'commonjs @emmetio/css-parser',
'@emmetio/html-matcher': 'commonjs @emmetio/html-matcher', '@emmetio/html-matcher': 'commonjs @emmetio/html-matcher',
'@emmetio/math-expression': 'commonjs @emmetio/math-expression', '@emmetio/math-expression': 'commonjs @emmetio/math-expression',
...@@ -21,4 +21,4 @@ const myConfig = { ...@@ -21,4 +21,4 @@ const myConfig = {
}, },
}; };
module.exports = { ...sharedConfig(__dirname), ...myConfig }; module.exports = withDefaults(myConfig);
...@@ -5,10 +5,11 @@ ...@@ -5,10 +5,11 @@
'use strict'; 'use strict';
const sharedConfig = require('../shared.webpack.config'); const withDefaults = require('../shared.webpack.config');
const CopyWebpackPlugin = require('copy-webpack-plugin'); const CopyWebpackPlugin = require('copy-webpack-plugin');
const myConfig = { const myConfig = {
context: __dirname,
node: { node: {
__dirname: false // leave the __dirname-behaviour intact __dirname: false // leave the __dirname-behaviour intact
}, },
...@@ -18,12 +19,10 @@ const myConfig = { ...@@ -18,12 +19,10 @@ const myConfig = {
}, },
plugins: [ plugins: [
new CopyWebpackPlugin([ new CopyWebpackPlugin([
{ from: './out/*.sh', to: '[name].sh' }, { from: './out/*.sh', to: '[name].sh' }
{ from: './out/nls.*.json', to: '[name].json' }
]) ])
], ],
externals: { externals: {
'vscode': 'commonjs vscode', // ignored because it doesn't exist
"byline": 'commonjs byline', "byline": 'commonjs byline',
"file-type": 'commonjs file-type', "file-type": 'commonjs file-type',
"iconv-lite": 'commonjs iconv-lite', "iconv-lite": 'commonjs iconv-lite',
...@@ -34,4 +33,4 @@ const myConfig = { ...@@ -34,4 +33,4 @@ const myConfig = {
}, },
}; };
module.exports = { ...sharedConfig(__dirname), ...myConfig }; module.exports = withDefaults(myConfig);
...@@ -6,15 +6,11 @@ ...@@ -6,15 +6,11 @@
'use strict'; 'use strict';
const path = require('path'); const path = require('path');
const CopyWebpackPlugin = require('copy-webpack-plugin');
const merge = require('merge-options');
/** module.exports = function withDefaults(extConfig) {
* Function that must be invoked with __dirname and that let defaultConfig = {
* returns a good default configuation for extensions that
* want to do webpack
*/
module.exports = function (extensionDir) {
return {
context: extensionDir,
mode: 'none', // this leaves the source code as close as possible to the original (when packaging we set this to 'production') 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 target: 'node', // extensions run in a node context
resolve: { resolve: {
...@@ -43,14 +39,75 @@ module.exports = function (extensionDir) { ...@@ -43,14 +39,75 @@ module.exports = function (extensionDir) {
}] }]
}] }]
}, },
plugins: [
new CopyWebpackPlugin([{ from: './out/nls.*.json', to: '[name].json' }]) // copy nls files
],
externals: {
'vscode': 'commonjs vscode', // ignored because it doesn't exist
},
output: { output: {
// all output goes into `dist`. // all output goes into `dist`.
// packaging depends on that and this must always be like it // packaging depends on that and this must always be like it
filename: '[name].js', filename: '[name].js',
path: path.join(extensionDir, 'dist'), path: path.join(extConfig.context, 'dist'),
libraryTarget: "commonjs", libraryTarget: "commonjs",
}, },
// yes, really source maps // yes, really source maps
devtool: 'source-map' devtool: 'source-map'
}; }
};
return merge(defaultConfig, extConfig);
}
// /**
// * Function that must be invoked with __dirname and that
// * returns a good default configuation for extensions that
// * want to do webpack
// */
// module.exports = function (extensionDir) {
// return {
// context: extensionDir,
// 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
// resolve: {
// mainFields: ['main'], // prefer the main-entry of package.json files
// extensions: ['.ts', '.js'] // support ts-files and js-files
// },
// module: {
// rules: [{
// test: /\.ts$/,
// exclude: /node_modules/,
// use: [{
// // vscode-nls-dev loader:
// // * rewrite nls-calls
// loader: 'vscode-nls-dev/lib/webpack-loader'
// }, {
// // configure TypeScript loader:
// // * only transpile because we have a separate compilation pipeline
// // * enable sources maps for end-to-end source maps
// loader: 'ts-loader',
// options: {
// transpileOnly: true,
// compilerOptions: {
// "sourceMap": true,
// }
// }
// }]
// }]
// },
// plugins: [
// new CopyWebpackPlugin([
// { from: './out/nls.*.json', to: '[name].json' }
// ])
// ],
// output: {
// // all output goes into `dist`.
// // packaging depends on that and this must always be like it
// filename: '[name].js',
// path: path.join(extensionDir, 'dist'),
// libraryTarget: "commonjs",
// },
// // yes, really source maps
// devtool: 'source-map'
// };
// };
...@@ -3909,7 +3909,7 @@ is-path-inside@^1.0.0: ...@@ -3909,7 +3909,7 @@ is-path-inside@^1.0.0:
dependencies: dependencies:
path-is-inside "^1.0.1" path-is-inside "^1.0.1"
is-plain-obj@^1.0.0: is-plain-obj@^1.0.0, is-plain-obj@^1.1:
version "1.1.0" version "1.1.0"
resolved "https://registry.yarnpkg.com/is-plain-obj/-/is-plain-obj-1.1.0.tgz#71a50c8429dfca773c92a390a4a03b39fcd51d3e" resolved "https://registry.yarnpkg.com/is-plain-obj/-/is-plain-obj-1.1.0.tgz#71a50c8429dfca773c92a390a4a03b39fcd51d3e"
...@@ -4724,6 +4724,12 @@ merge-descriptors@1.0.1: ...@@ -4724,6 +4724,12 @@ merge-descriptors@1.0.1:
version "1.0.1" version "1.0.1"
resolved "https://registry.yarnpkg.com/merge-descriptors/-/merge-descriptors-1.0.1.tgz#b00aaa556dd8b44568150ec9d1b953f3f90cbb61" resolved "https://registry.yarnpkg.com/merge-descriptors/-/merge-descriptors-1.0.1.tgz#b00aaa556dd8b44568150ec9d1b953f3f90cbb61"
merge-options@^1.0.1:
version "1.0.1"
resolved "https://registry.yarnpkg.com/merge-options/-/merge-options-1.0.1.tgz#2a64b24457becd4e4dc608283247e94ce589aa32"
dependencies:
is-plain-obj "^1.1"
merge-stream@^1.0.0: merge-stream@^1.0.0:
version "1.0.1" version "1.0.1"
resolved "https://registry.yarnpkg.com/merge-stream/-/merge-stream-1.0.1.tgz#4041202d508a342ba00174008df0c251b8c135e1" resolved "https://registry.yarnpkg.com/merge-stream/-/merge-stream-1.0.1.tgz#4041202d508a342ba00174008df0c251b8c135e1"
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册