Skip to content

Commit

Permalink
build: add runtime-global build for vue
Browse files Browse the repository at this point in the history
  • Loading branch information
yyx990803 committed Mar 23, 2020
1 parent f529dbd commit 4126a9d
Show file tree
Hide file tree
Showing 3 changed files with 32 additions and 23 deletions.
1 change: 1 addition & 0 deletions packages/vue/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -18,6 +18,7 @@
"esm-bundler-runtime",
"cjs",
"global",
"global-runtime",
"esm"
]
},
Expand Down
23 changes: 13 additions & 10 deletions rollup.config.js
Original file line number Diff line number Diff line change
Expand Up @@ -23,11 +23,6 @@ const outputConfigs = {
file: resolve(`dist/${name}.esm-bundler.js`),
format: `es`
},
// main "vue" package only
'esm-bundler-runtime': {
file: resolve(`dist/${name}.runtime.esm-bundler.js`),
format: `es`
},
cjs: {
file: resolve(`dist/${name}.cjs.js`),
format: `cjs`
Expand All @@ -39,6 +34,15 @@ const outputConfigs = {
esm: {
file: resolve(`dist/${name}.esm.js`),
format: `es`
},
// main "vue" package only
'esm-bundler-runtime': {
file: resolve(`dist/${name}.runtime.esm-bundler.js`),
format: `es`
},
'global-runtime': {
file: resolve(`dist/${name}.runtime.global.js`),
format: 'iife'
}
}

Expand All @@ -54,7 +58,7 @@ if (process.env.NODE_ENV === 'production') {
if (format === 'cjs' && packageOptions.prod !== false) {
packageConfigs.push(createProductionConfig(format))
}
if (format === 'global' || format === 'esm') {
if (/global/.test(format) || format === 'esm') {
packageConfigs.push(createMinifiedConfig(format))
}
})
Expand All @@ -73,7 +77,7 @@ function createConfig(format, output, plugins = []) {

const isProductionBuild =
process.env.__DEV__ === 'false' || /\.prod\.js$/.test(output.file)
const isGlobalBuild = format === 'global'
const isGlobalBuild = /global/.test(format)
const isRawESMBuild = format === 'esm'
const isNodeBuild = format === 'cjs'
const isBundlerESMBuild = /esm-bundler/.test(format)
Expand Down Expand Up @@ -102,8 +106,7 @@ function createConfig(format, output, plugins = []) {
// during a single build.
hasTSChecked = true

const entryFile =
format === 'esm-bundler-runtime' ? `src/runtime.ts` : `src/index.ts`
const entryFile = /runtime$/.test(format) ? `src/runtime.ts` : `src/index.ts`

const external =
isGlobalBuild || isRawESMBuild
Expand Down Expand Up @@ -210,7 +213,7 @@ function createMinifiedConfig(format) {
return createConfig(
format,
{
file: resolve(`dist/${name}.${format}.prod.js`),
file: outputConfigs[format].file.replace(/\.js$/, '.prod.js'),
format: outputConfigs[format].format
},
[
Expand Down
31 changes: 18 additions & 13 deletions scripts/build.js
Original file line number Diff line number Diff line change
Expand Up @@ -148,18 +148,23 @@ function checkAllSizes(targets) {

function checkSize(target) {
const pkgDir = path.resolve(`packages/${target}`)
const esmProdBuild = `${pkgDir}/dist/${target}.global.prod.js`
if (fs.existsSync(esmProdBuild)) {
const file = fs.readFileSync(esmProdBuild)
const minSize = (file.length / 1024).toFixed(2) + 'kb'
const gzipped = gzipSync(file)
const gzippedSize = (gzipped.length / 1024).toFixed(2) + 'kb'
const compressed = compress(file)
const compressedSize = (compressed.length / 1024).toFixed(2) + 'kb'
console.log(
`${chalk.gray(
chalk.bold(target)
)} min:${minSize} / gzip:${gzippedSize} / brotli:${compressedSize}`
)
checkFileSize(`${pkgDir}/dist/${target}.global.prod.js`)
checkFileSize(`${pkgDir}/dist/${target}.runtime.global.prod.js`)
}

function checkFileSize(filePath) {
if (!fs.existsSync(filePath)) {
return
}
const file = fs.readFileSync(filePath)
const minSize = (file.length / 1024).toFixed(2) + 'kb'
const gzipped = gzipSync(file)
const gzippedSize = (gzipped.length / 1024).toFixed(2) + 'kb'
const compressed = compress(file)
const compressedSize = (compressed.length / 1024).toFixed(2) + 'kb'
console.log(
`${chalk.gray(
chalk.bold(path.basename(filePath))
)} min:${minSize} / gzip:${gzippedSize} / brotli:${compressedSize}`
)
}

0 comments on commit 4126a9d

Please sign in to comment.