mirror of https://github.com/curbengh/hexo-yam
Merge pull request #14 from weyusi/micromatch
feat: switch nanomatch to micromatch
This commit is contained in:
commit
ba77db0094
|
@ -36,11 +36,12 @@ neat_html:
|
||||||
```
|
```
|
||||||
- **enable** - Enable the plugin. Defaults to `true`.
|
- **enable** - Enable the plugin. Defaults to `true`.
|
||||||
- **logger** - Verbose output. Defaults to `false`.
|
- **logger** - Verbose output. Defaults to `false`.
|
||||||
- **exclude** - Exclude files. Support [wildcard](https://github.com/micromatch/nanomatch#features) glob pattern.
|
- **exclude** - Exclude files.
|
||||||
- Support one-liner, `exclude: [*.min.html, *.note.html]`.
|
- Support one-liner, `exclude: [*.min.html, *.note.html]`.
|
||||||
- To exclude a file, double asterisk and the full path must be specified, `**/themes/typing/source/js/source.js`.
|
- To exclude a file, double asterisk and the full path must be specified, `**/themes/typing/source/js/source.js`.
|
||||||
- `*source.js` also works, but it also excludes `resource.js`.
|
- `*source.js` also works, but it also excludes `resource.js`.
|
||||||
- Test glob pattern on the web using [Globtester](http://www.globtester.com/).
|
- Test glob pattern on the web using [Globtester](http://www.globtester.com/).
|
||||||
|
- **globOptions** - [micromatch options](https://github.com/micromatch/micromatch#options) to customise how glob patterns match files. Defaults to `{ matchBase: true }`.
|
||||||
|
|
||||||
For more options, see [HTMLMinifier](https://github.com/kangax/html-minifier).
|
For more options, see [HTMLMinifier](https://github.com/kangax/html-minifier).
|
||||||
|
|
||||||
|
@ -56,6 +57,7 @@ neat_css:
|
||||||
- **logger** - Verbose output. Defaults to `false`.
|
- **logger** - Verbose output. Defaults to `false`.
|
||||||
- **exclude** - Exclude files. Support wildcard pattern.
|
- **exclude** - Exclude files. Support wildcard pattern.
|
||||||
- **level** - Optimization level. Defaults to `2`.
|
- **level** - Optimization level. Defaults to `2`.
|
||||||
|
- **globOptions** - [micromatch options](https://github.com/micromatch/micromatch#options) to customise how glob patterns match files. Defaults to `{ matchBase: true }`.
|
||||||
|
|
||||||
For more options, see [clean-css](https://github.com/jakubpawlowicz/clean-css).
|
For more options, see [clean-css](https://github.com/jakubpawlowicz/clean-css).
|
||||||
|
|
||||||
|
@ -74,6 +76,7 @@ neat_js:
|
||||||
- **mangle** - Mangle variable names. Defaults to `true`. Pass an object to specify [mangle options](https://github.com/terser-js/terser#mangle-options).
|
- **mangle** - Mangle variable names. Defaults to `true`. Pass an object to specify [mangle options](https://github.com/terser-js/terser#mangle-options).
|
||||||
- **output** - Output options.
|
- **output** - Output options.
|
||||||
- To retain comments, `output: {comments: true}`.
|
- To retain comments, `output: {comments: true}`.
|
||||||
|
- **globOptions** - [micromatch options](https://github.com/micromatch/micromatch#options) to customise how glob patterns match files. Defaults to `{ matchBase: true }`.
|
||||||
|
|
||||||
For more options, see [Terser](https://github.com/terser-js/terser).
|
For more options, see [Terser](https://github.com/terser-js/terser).
|
||||||
|
|
||||||
|
@ -92,6 +95,7 @@ neat_svg:
|
||||||
- Exclude `*.min.svg` by default.
|
- Exclude `*.min.svg` by default.
|
||||||
- **plugins** - Plugin options.
|
- **plugins** - Plugin options.
|
||||||
- To retain comments, `plugins: [{removeComments: false}]`.
|
- To retain comments, `plugins: [{removeComments: false}]`.
|
||||||
|
- **globOptions** - [micromatch options](https://github.com/micromatch/micromatch#options) to customise how glob patterns match files. Defaults to `{ matchBase: true }`.
|
||||||
|
|
||||||
For more options, see [svgo](https://github.com/svg/svgo).
|
For more options, see [svgo](https://github.com/svg/svgo).
|
||||||
|
|
||||||
|
@ -118,6 +122,7 @@ neat_gzip:
|
||||||
- **include** - Include files. Support wildcard pattern.
|
- **include** - Include files. Support wildcard pattern.
|
||||||
- Support one-liner, `include: ['*.html','*.css','*.js']`.
|
- Support one-liner, `include: ['*.html','*.css','*.js']`.
|
||||||
- Must include asterisk and single quotes. `.html` is invalid. `'*.html'` is valid.
|
- Must include asterisk and single quotes. `.html` is invalid. `'*.html'` is valid.
|
||||||
|
- **globOptions** - [micromatch options](https://github.com/micromatch/micromatch#options) to customise how glob patterns match files. Defaults to `{ matchBase: true }`.
|
||||||
|
|
||||||
----------
|
----------
|
||||||
|
|
||||||
|
@ -140,6 +145,7 @@ neat_brotli:
|
||||||
- **enable** - Enable the plugin. Defaults to `true`.
|
- **enable** - Enable the plugin. Defaults to `true`.
|
||||||
- **logger** - Verbose output. Defaults to `false`.
|
- **logger** - Verbose output. Defaults to `false`.
|
||||||
- **include** - Include files. Support wildcard pattern.
|
- **include** - Include files. Support wildcard pattern.
|
||||||
|
- **globOptions** - [micromatch options](https://github.com/micromatch/micromatch#options) to customise how glob patterns match files. Defaults to `{ matchBase: true }`.
|
||||||
|
|
||||||
## HTTP Compression
|
## HTTP Compression
|
||||||
While most modern web browsers [support Brotli](https://www.caniuse.com/#feat=brotli), you also need to consider whether the web/app server, hosting platform, reverse proxy or CDN (whichever relevant to you) support it.
|
While most modern web browsers [support Brotli](https://www.caniuse.com/#feat=brotli), you also need to consider whether the web/app server, hosting platform, reverse proxy or CDN (whichever relevant to you) support it.
|
||||||
|
|
18
index.js
18
index.js
|
@ -16,7 +16,8 @@ if (hexo.config.neat_enable === true) {
|
||||||
removeScriptTypeAttributes: true,
|
removeScriptTypeAttributes: true,
|
||||||
removeStyleLinkTypeAttributes: true,
|
removeStyleLinkTypeAttributes: true,
|
||||||
minifyJS: true,
|
minifyJS: true,
|
||||||
minifyCSS: true
|
minifyCSS: true,
|
||||||
|
globOptions: { matchBase: true }
|
||||||
}, hexo.config.neat_html)
|
}, hexo.config.neat_html)
|
||||||
|
|
||||||
// CSS minifier
|
// CSS minifier
|
||||||
|
@ -24,7 +25,8 @@ if (hexo.config.neat_enable === true) {
|
||||||
enable: true,
|
enable: true,
|
||||||
logger: false,
|
logger: false,
|
||||||
exclude: ['*.min.css'],
|
exclude: ['*.min.css'],
|
||||||
level: 2
|
level: 2,
|
||||||
|
globOptions: { matchBase: true }
|
||||||
}, hexo.config.neat_css)
|
}, hexo.config.neat_css)
|
||||||
|
|
||||||
// Javascript minifier
|
// Javascript minifier
|
||||||
|
@ -34,7 +36,8 @@ if (hexo.config.neat_enable === true) {
|
||||||
exclude: ['*.min.js'],
|
exclude: ['*.min.js'],
|
||||||
compress: {},
|
compress: {},
|
||||||
mangle: true,
|
mangle: true,
|
||||||
output: {}
|
output: {},
|
||||||
|
globOptions: { matchBase: true }
|
||||||
}, hexo.config.neat_js)
|
}, hexo.config.neat_js)
|
||||||
|
|
||||||
// SVG minifier
|
// SVG minifier
|
||||||
|
@ -42,21 +45,24 @@ if (hexo.config.neat_enable === true) {
|
||||||
enable: true,
|
enable: true,
|
||||||
logger: false,
|
logger: false,
|
||||||
include: ['*.svg', '!*.min.svg'],
|
include: ['*.svg', '!*.min.svg'],
|
||||||
plugins: []
|
plugins: [],
|
||||||
|
globOptions: { matchBase: true }
|
||||||
}, hexo.config.neat_svg)
|
}, hexo.config.neat_svg)
|
||||||
|
|
||||||
// gzip compression
|
// gzip compression
|
||||||
hexo.config.neat_gzip = Object.assign({
|
hexo.config.neat_gzip = Object.assign({
|
||||||
enable: true,
|
enable: true,
|
||||||
logger: false,
|
logger: false,
|
||||||
include: ['*.html', '*.css', '*.js', '*.txt', '*.ttf', '*.atom', '*.stl', '*.xml', '*.svg', '*.eot', '*.json']
|
include: ['*.html', '*.css', '*.js', '*.txt', '*.ttf', '*.atom', '*.stl', '*.xml', '*.svg', '*.eot', '*.json'],
|
||||||
|
globOptions: { matchBase: true }
|
||||||
}, hexo.config.neat_gzip)
|
}, hexo.config.neat_gzip)
|
||||||
|
|
||||||
// brotli compression
|
// brotli compression
|
||||||
hexo.config.neat_brotli = Object.assign({
|
hexo.config.neat_brotli = Object.assign({
|
||||||
enable: true,
|
enable: true,
|
||||||
logger: false,
|
logger: false,
|
||||||
include: ['*.html', '*.css', '*.js', '*.txt', '*.ttf', '*.atom', '*.stl', '*.xml', '*.svg', '*.eot', '*.json']
|
include: ['*.html', '*.css', '*.js', '*.txt', '*.ttf', '*.atom', '*.stl', '*.xml', '*.svg', '*.eot', '*.json'],
|
||||||
|
globOptions: { matchBase: true }
|
||||||
}, hexo.config.neat_brotli)
|
}, hexo.config.neat_brotli)
|
||||||
|
|
||||||
const filter = require('./lib/filter')
|
const filter = require('./lib/filter')
|
||||||
|
|
|
@ -1,13 +1,20 @@
|
||||||
/* global hexo */
|
|
||||||
'use strict'
|
'use strict'
|
||||||
|
|
||||||
const Htmlminifier = require('html-minifier').minify
|
const Htmlminifier = require('html-minifier').minify
|
||||||
const CleanCSS = require('clean-css')
|
const CleanCSS = require('clean-css')
|
||||||
const Terser = require('terser')
|
const Terser = require('terser')
|
||||||
const svgo = require('svgo')
|
const Svgo = require('svgo')
|
||||||
const zlib = require('zlib')
|
const zlib = require('zlib')
|
||||||
const br = require('iltorb')
|
const br = require('iltorb')
|
||||||
const nanomatch = require('nanomatch')
|
const micromatch = require('micromatch')
|
||||||
|
|
||||||
|
function isMatch (path, patterns, options) {
|
||||||
|
if (path && patterns && patterns.length) {
|
||||||
|
return micromatch.isMatch(path, patterns, options)
|
||||||
|
} else {
|
||||||
|
return false
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
function logicHtml (str, data) {
|
function logicHtml (str, data) {
|
||||||
const hexo = this
|
const hexo = this
|
||||||
|
@ -15,13 +22,12 @@ function logicHtml (str, data) {
|
||||||
// Return if disabled.
|
// Return if disabled.
|
||||||
if (options.enable === false) return
|
if (options.enable === false) return
|
||||||
|
|
||||||
let path = data.path
|
const path = data.path
|
||||||
let exclude = options.exclude
|
const exclude = options.exclude
|
||||||
|
const globOptions = options.globOptions
|
||||||
|
|
||||||
// Return if a path matches exclusion pattern
|
// Return if a path matches exclusion pattern
|
||||||
if (path && exclude && exclude.length) {
|
if (isMatch(path, exclude, globOptions)) return str
|
||||||
if (nanomatch.some(path, exclude, { matchBase: true })) return str
|
|
||||||
}
|
|
||||||
|
|
||||||
let result = Htmlminifier(str, options)
|
let result = Htmlminifier(str, options)
|
||||||
let saved = ((str.length - result.length) / str.length * 100).toFixed(2)
|
let saved = ((str.length - result.length) / str.length * 100).toFixed(2)
|
||||||
|
@ -35,16 +41,13 @@ function logicHtml (str, data) {
|
||||||
function logicCss (str, data) {
|
function logicCss (str, data) {
|
||||||
const hexo = this
|
const hexo = this
|
||||||
const options = hexo.config.neat_css
|
const options = hexo.config.neat_css
|
||||||
// Return if disabled.
|
|
||||||
if (options.enable === false) return
|
if (options.enable === false) return
|
||||||
|
|
||||||
let path = data.path
|
const path = data.path
|
||||||
let exclude = options.exclude
|
const exclude = options.exclude
|
||||||
|
const globOptions = options.globOptions
|
||||||
|
|
||||||
// Return if a path matches exclusion pattern
|
if (isMatch(path, exclude, globOptions)) return str
|
||||||
if (path && exclude && exclude.length) {
|
|
||||||
if (nanomatch.some(path, exclude, { matchBase: true })) return str
|
|
||||||
}
|
|
||||||
|
|
||||||
return new Promise((resolve, reject) => {
|
return new Promise((resolve, reject) => {
|
||||||
new CleanCSS(options).minify(str, (err, result) => {
|
new CleanCSS(options).minify(str, (err, result) => {
|
||||||
|
@ -62,22 +65,20 @@ function logicCss (str, data) {
|
||||||
function logicJs (str, data) {
|
function logicJs (str, data) {
|
||||||
const hexo = this
|
const hexo = this
|
||||||
const options = hexo.config.neat_js
|
const options = hexo.config.neat_js
|
||||||
// Return if disabled.
|
|
||||||
if (options.enable === false) return
|
if (options.enable === false) return
|
||||||
|
|
||||||
let path = data.path
|
const path = data.path
|
||||||
let exclude = options.exclude
|
const exclude = options.exclude
|
||||||
|
const globOptions = options.globOptions
|
||||||
|
|
||||||
// Return if a path matches exclusion pattern
|
if (isMatch(path, exclude, globOptions)) return str
|
||||||
if (path && exclude && exclude.length) {
|
|
||||||
if (nanomatch.some(path, exclude, { matchBase: true })) return str
|
|
||||||
}
|
|
||||||
|
|
||||||
// Terser doesn't like unsupported options
|
// Terser doesn't like unsupported options
|
||||||
const jsOptions = Object.assign({}, options)
|
const jsOptions = Object.assign({}, options)
|
||||||
delete jsOptions.enable
|
delete jsOptions.enable
|
||||||
delete jsOptions.exclude
|
delete jsOptions.exclude
|
||||||
delete jsOptions.logger
|
delete jsOptions.logger
|
||||||
|
delete jsOptions.globOptions
|
||||||
|
|
||||||
let result = Terser.minify(str, jsOptions)
|
let result = Terser.minify(str, jsOptions)
|
||||||
let saved = ((str.length - result.code.length) / str.length * 100).toFixed(2)
|
let saved = ((str.length - result.code.length) / str.length * 100).toFixed(2)
|
||||||
|
@ -97,8 +98,9 @@ function logicSvg () {
|
||||||
let route = hexo.route
|
let route = hexo.route
|
||||||
let routeList = route.list()
|
let routeList = route.list()
|
||||||
let include = options.include
|
let include = options.include
|
||||||
|
const globOptions = options.globOptions
|
||||||
|
|
||||||
return Promise.all((nanomatch(routeList, include, { matchBase: true })).map(path => {
|
return Promise.all((micromatch(routeList, include, globOptions)).map(path => {
|
||||||
return new Promise((resolve, reject) => {
|
return new Promise((resolve, reject) => {
|
||||||
// Grab all assets using hexo router
|
// Grab all assets using hexo router
|
||||||
let assetPath = route.get(path)
|
let assetPath = route.get(path)
|
||||||
|
@ -108,7 +110,7 @@ function logicSvg () {
|
||||||
assetPath.on('end', () => {
|
assetPath.on('end', () => {
|
||||||
if (assetTxt.length) {
|
if (assetTxt.length) {
|
||||||
// Minify using svgo
|
// Minify using svgo
|
||||||
new svgo(options).optimize(assetTxt).then((result) => {
|
new Svgo(options).optimize(assetTxt).then((result) => {
|
||||||
// Replace the original file with the minified.
|
// Replace the original file with the minified.
|
||||||
route.set(path, result.data)
|
route.set(path, result.data)
|
||||||
// Logging
|
// Logging
|
||||||
|
@ -134,8 +136,9 @@ function logicGzip () {
|
||||||
let route = hexo.route
|
let route = hexo.route
|
||||||
let routeList = route.list()
|
let routeList = route.list()
|
||||||
let include = options.include
|
let include = options.include
|
||||||
|
const globOptions = options.globOptions
|
||||||
|
|
||||||
return Promise.all((nanomatch(routeList, include, { matchBase: true })).map(path => {
|
return Promise.all((micromatch(routeList, include, globOptions)).map(path => {
|
||||||
return new Promise((resolve, reject) => {
|
return new Promise((resolve, reject) => {
|
||||||
// Grab all assets using hexo router
|
// Grab all assets using hexo router
|
||||||
let assetPath = route.get(path)
|
let assetPath = route.get(path)
|
||||||
|
@ -175,8 +178,9 @@ function logicBrotli () {
|
||||||
let route = hexo.route
|
let route = hexo.route
|
||||||
let routeList = route.list()
|
let routeList = route.list()
|
||||||
let include = options.include
|
let include = options.include
|
||||||
|
const globOptions = options.globOptions
|
||||||
|
|
||||||
return Promise.all((nanomatch(routeList, include, { matchBase: true })).map(path => {
|
return Promise.all((micromatch(routeList, include, globOptions)).map(path => {
|
||||||
return new Promise((resolve, reject) => {
|
return new Promise((resolve, reject) => {
|
||||||
// Grab all assets using hexo router
|
// Grab all assets using hexo router
|
||||||
let assetPath = route.get(path)
|
let assetPath = route.get(path)
|
||||||
|
|
|
@ -25,7 +25,7 @@
|
||||||
"clean-css": "^4.2.1",
|
"clean-css": "^4.2.1",
|
||||||
"html-minifier": "^4.0.0",
|
"html-minifier": "^4.0.0",
|
||||||
"iltorb": "^2.4.2",
|
"iltorb": "^2.4.2",
|
||||||
"nanomatch": "^1.2.13",
|
"micromatch": "^4.0.2",
|
||||||
"svgo": "^1.2.2",
|
"svgo": "^1.2.2",
|
||||||
"terser": "^4.0.0"
|
"terser": "^4.0.0"
|
||||||
},
|
},
|
||||||
|
|
Loading…
Reference in New Issue