Skip to content

Commit

Permalink
Revert "Replace rollup’s uglify plugin with terser"
Browse files Browse the repository at this point in the history
This reverts commit 7ba8513.
  • Loading branch information
jhildenbiddle committed Mar 4, 2022
1 parent 3f2dd46 commit e06fed4
Show file tree
Hide file tree
Showing 3 changed files with 112 additions and 218 deletions.
159 changes: 78 additions & 81 deletions build/build.js
Original file line number Diff line number Diff line change
@@ -1,13 +1,13 @@
const rollup = require('rollup');
const buble = require('rollup-plugin-buble');
const commonjs = require('rollup-plugin-commonjs');
const nodeResolve = require('rollup-plugin-node-resolve');
const { terser } = require('rollup-plugin-terser');
const replace = require('rollup-plugin-replace');
const isProd = process.env.NODE_ENV === 'production';
const version = process.env.VERSION || require('../package.json').version;
const chokidar = require('chokidar');
const path = require('path');
const rollup = require('rollup')
const buble = require('rollup-plugin-buble')
const commonjs = require('rollup-plugin-commonjs')
const nodeResolve = require('rollup-plugin-node-resolve')
const { uglify } = require('rollup-plugin-uglify')
const replace = require('rollup-plugin-replace')
const isProd = process.env.NODE_ENV === 'production'
const version = process.env.VERSION || require('../package.json').version
const chokidar = require('chokidar')
const path = require('path')

/**
* @param {{
Expand All @@ -24,96 +24,89 @@ async function build(opts) {
plugins: (opts.plugins || []).concat([
buble({
transforms: {
dangerousForOf: true,
},
}),
dangerousForOf: true
}}),
commonjs(),
nodeResolve(),
replace({
__VERSION__: version,
'process.env.SSR': false,
}),
'process.env.SSR': false
})
]),
onwarn: function (message) {
if (message.code === 'UNRESOLVED_IMPORT') {
throw new Error(
`Could not resolve module ` +
message.source +
`. Try running 'npm install' or using rollup's 'external' option if this is an external dependency. ` +
`Module ${message.source} is imported in ${message.importer}`
);
message.source +
`. Try running 'npm install' or using rollup's 'external' option if this is an external dependency. ` +
`Module ${message.source} is imported in ${message.importer}`
)
}
},
}
})
.then(function (bundle) {
var dest = 'lib/' + (opts.output || opts.input);
var dest = 'lib/' + (opts.output || opts.input)

console.log(dest);
console.log(dest)
return bundle.write({
format: 'iife',
output: opts.globalName ? { name: opts.globalName } : {},
output: opts.globalName ? {name: opts.globalName} : {},
file: dest,
strict: false,
});
});
strict: false
})
})
}

async function buildCore() {
const promises = [];
const promises = []

promises.push(
build({
input: 'src/core/index.js',
output: 'docsify.js',
})
);
promises.push(build({
input: 'src/core/index.js',
output: 'docsify.js',
}))

if (isProd) {
promises.push(
build({
input: 'src/core/index.js',
output: 'docsify.min.js',
plugins: [terser()],
})
);
promises.push(build({
input: 'src/core/index.js',
output: 'docsify.min.js',
plugins: [uglify()]
}))
}

await Promise.all(promises);
await Promise.all(promises)
}

async function buildAllPlugin() {
var plugins = [
{ name: 'search', input: 'search/index.js' },
{ name: 'ga', input: 'ga.js' },
{ name: 'matomo', input: 'matomo.js' },
{ name: 'emoji', input: 'emoji.js' },
{ name: 'external-script', input: 'external-script.js' },
{ name: 'front-matter', input: 'front-matter/index.js' },
{ name: 'zoom-image', input: 'zoom-image.js' },
{ name: 'disqus', input: 'disqus.js' },
{ name: 'gitalk', input: 'gitalk.js' },
];
{name: 'search', input: 'search/index.js'},
{name: 'ga', input: 'ga.js'},
{name: 'matomo', input: 'matomo.js'},
{name: 'emoji', input: 'emoji.js'},
{name: 'external-script', input: 'external-script.js'},
{name: 'front-matter', input: 'front-matter/index.js'},
{name: 'zoom-image', input: 'zoom-image.js'},
{name: 'disqus', input: 'disqus.js'},
{name: 'gitalk', input: 'gitalk.js'}
]

const promises = plugins.map(item => {
return build({
input: 'src/plugins/' + item.input,
output: 'plugins/' + item.name + '.js',
});
});
output: 'plugins/' + item.name + '.js'
})
})

if (isProd) {
plugins.forEach(item => {
promises.push(
build({
input: 'src/plugins/' + item.input,
output: 'plugins/' + item.name + '.min.js',
plugins: [terser()],
})
);
});
promises.push(build({
input: 'src/plugins/' + item.input,
output: 'plugins/' + item.name + '.min.js',
plugins: [uglify()]
}))
})
}

await Promise.all(promises);
await Promise.all(promises)
}

async function main() {
Expand All @@ -123,37 +116,41 @@ async function main() {
atomic: true,
awaitWriteFinish: {
stabilityThreshold: 1000,
pollInterval: 100,
},
pollInterval: 100
}
})
.on('change', p => {
console.log('[watch] ', p);
const dirs = p.split(path.sep);
console.log('[watch] ', p)
const dirs = p.split(path.sep)
if (dirs[1] === 'core') {
buildCore();
buildCore()
} else if (dirs[2]) {
const name = path.basename(dirs[2], '.js');
const name = path.basename(dirs[2], '.js')
const input = `src/plugins/${name}${
/\.js/.test(dirs[2]) ? '' : '/index'
}.js`;
}.js`

build({
input,
output: 'plugins/' + name + '.js',
});
output: 'plugins/' + name + '.js'
})
}
})
.on('ready', () => {
console.log('[start]');
buildCore();
buildAllPlugin();
});
console.log('[start]')
buildCore()
buildAllPlugin()
})
} else {
await Promise.all([buildCore(), buildAllPlugin()]);
await Promise.all([
buildCore(),
buildAllPlugin()
])
}
}

main().catch(e => {
console.error(e);
process.exit(1);
});
main().catch((e) => {
console.error(e)
process.exit(1)
})

Loading

0 comments on commit e06fed4

Please sign in to comment.