From d01a2e0dcc49e99b971cec9e91c0b37e7d27f2ae Mon Sep 17 00:00:00 2001 From: bloody-ux Date: Wed, 20 Nov 2019 21:21:47 +0800 Subject: [PATCH] feat: supported `umd.sourcemap` option (#151) --- README.md | 9 ++++++++- .../build/rollup-umd-sourcemap/.fatherrc.js | 8 ++++++++ .../rollup-umd-sourcemap/expected/index.umd.js | 14 ++++++++++++++ .../rollup-umd-sourcemap/expected/index.umd.js.map | 1 + .../build/rollup-umd-sourcemap/src/index.js | 4 ++++ packages/father-build/src/getRollupConfig.ts | 2 ++ packages/father-build/src/schema.test.ts | 2 +- packages/father-build/src/schema.ts | 1 + packages/father-build/src/types.d.ts | 1 + 9 files changed, 40 insertions(+), 2 deletions(-) create mode 100644 packages/father-build/src/fixtures/build/rollup-umd-sourcemap/.fatherrc.js create mode 100644 packages/father-build/src/fixtures/build/rollup-umd-sourcemap/expected/index.umd.js create mode 100644 packages/father-build/src/fixtures/build/rollup-umd-sourcemap/expected/index.umd.js.map create mode 100644 packages/father-build/src/fixtures/build/rollup-umd-sourcemap/src/index.js diff --git a/README.md b/README.md index 30f69f2b..3557a25c 100644 --- a/README.md +++ b/README.md @@ -236,7 +236,7 @@ cjs 为 `rollup` 或 `babel` 时,等同于配置了 `{ type: "rollup" | "babel 是否输出 umd 格式,以及指定 umd 的相关配置。 -* Type: `{ globals, name, minFile, file } | false` +* Type: `{ globals, name, minFile, file, sourcemap } | false` * Default: `false` #### umd.globals @@ -264,6 +264,13 @@ cjs 为 `rollup` 或 `babel` 时,等同于配置了 `{ type: "rollup" | "babel - Type: `string` - Default: `undefined` +#### umd.sourcemap + +是否同步输出sourcemap。 + +- Type: `boolean` +- Default: `undefined` + #### autoprefixer 配置参数传给 autoprefixer,详见 [autoprefixer#options](https://github.com/postcss/autoprefixer#options),常用的有 `flexbox` 和 `browsers`。 diff --git a/packages/father-build/src/fixtures/build/rollup-umd-sourcemap/.fatherrc.js b/packages/father-build/src/fixtures/build/rollup-umd-sourcemap/.fatherrc.js new file mode 100644 index 00000000..ff17b207 --- /dev/null +++ b/packages/father-build/src/fixtures/build/rollup-umd-sourcemap/.fatherrc.js @@ -0,0 +1,8 @@ + +export default { + umd: { + minFile: false, + name: 'foo', + sourcemap: true, + }, +} diff --git a/packages/father-build/src/fixtures/build/rollup-umd-sourcemap/expected/index.umd.js b/packages/father-build/src/fixtures/build/rollup-umd-sourcemap/expected/index.umd.js new file mode 100644 index 00000000..d6585f4f --- /dev/null +++ b/packages/father-build/src/fixtures/build/rollup-umd-sourcemap/expected/index.umd.js @@ -0,0 +1,14 @@ +(function (global, factory) { + typeof exports === 'object' && typeof module !== 'undefined' ? module.exports = factory() : + typeof define === 'function' && define.amd ? define(factory) : + (global = global || self, global.foo = factory()); +}(this, function () { 'use strict'; + + function index () { + return 'foo'; + } + + return index; + +})); +//# sourceMappingURL=index.umd.js.map diff --git a/packages/father-build/src/fixtures/build/rollup-umd-sourcemap/expected/index.umd.js.map b/packages/father-build/src/fixtures/build/rollup-umd-sourcemap/expected/index.umd.js.map new file mode 100644 index 00000000..bf6d50af --- /dev/null +++ b/packages/father-build/src/fixtures/build/rollup-umd-sourcemap/expected/index.umd.js.map @@ -0,0 +1 @@ +{"version":3,"file":"index.umd.js","sources":["../src/index.js"],"sourcesContent":["\nexport default function () {\n return 'foo';\n}\n"],"names":[],"mappings":";;;;;;EACe,kBAAY;EACzB,SAAO,KAAP;EACD;;;;;;;;"} \ No newline at end of file diff --git a/packages/father-build/src/fixtures/build/rollup-umd-sourcemap/src/index.js b/packages/father-build/src/fixtures/build/rollup-umd-sourcemap/src/index.js new file mode 100644 index 00000000..8fcf68e1 --- /dev/null +++ b/packages/father-build/src/fixtures/build/rollup-umd-sourcemap/src/index.js @@ -0,0 +1,4 @@ + +export default function () { + return 'foo'; +} diff --git a/packages/father-build/src/getRollupConfig.ts b/packages/father-build/src/getRollupConfig.ts index 898ded6c..30d36abb 100644 --- a/packages/father-build/src/getRollupConfig.ts +++ b/packages/father-build/src/getRollupConfig.ts @@ -266,6 +266,7 @@ export default function(opts: IGetRollupConfigOpts): RollupOptions[] { input, output: { format, + sourcemap: umd && umd.sourcemap, file: join(cwd, `dist/${(umd && umd.file) || `${name}.umd`}.js`), globals: umd && umd.globals, name: (umd && umd.name) || (pkg.name && camelCase(basename(pkg.name))), @@ -286,6 +287,7 @@ export default function(opts: IGetRollupConfigOpts): RollupOptions[] { input, output: { format, + sourcemap: umd && umd.sourcemap, file: join(cwd, `dist/${(umd && umd.file) || `${name}.umd`}.min.js`), globals: umd && umd.globals, name: (umd && umd.name) || (pkg.name && camelCase(basename(pkg.name))), diff --git a/packages/father-build/src/schema.test.ts b/packages/father-build/src/schema.test.ts index 6a586fae..10cbdf4b 100644 --- a/packages/father-build/src/schema.test.ts +++ b/packages/father-build/src/schema.test.ts @@ -8,7 +8,7 @@ const successValidates = { file: ['a'], esm: [false, true, { type: 'rollup' }, { type: 'babel' }, { file: 'a' }, { mjs: true }], cjs: [false, true, { type: 'rollup' }, { type: 'babel' }, { file: 'a' }], - umd: [{ globals: {} }, { file: 'a' }, { name: 'a' }, { minFile: false }, { minFile: true }], + umd: [{ globals: {} }, { file: 'a' }, { name: 'a' }, { minFile: false }, { minFile: true }, { sourcemap: true }], extraBabelPlugins: [[]], extraBabelPresets: [[]], extraPostCSSPlugins: [[]], diff --git a/packages/father-build/src/schema.ts b/packages/father-build/src/schema.ts index c9945d53..687f625f 100644 --- a/packages/father-build/src/schema.ts +++ b/packages/father-build/src/schema.ts @@ -60,6 +60,7 @@ export default { file: noEmptyStr, name: noEmptyStr, minFile: { type: 'boolean' }, + sourcemap: { type: 'boolean' }, }, }, ], diff --git a/packages/father-build/src/types.d.ts b/packages/father-build/src/types.d.ts index 04c2d425..8cd3403d 100644 --- a/packages/father-build/src/types.d.ts +++ b/packages/father-build/src/types.d.ts @@ -29,6 +29,7 @@ interface IUmd { name?: string; minFile?: boolean; file?: string; + sourcemap?: boolean; } export interface IBundleOptions {