Skip to content

Commit

Permalink
Revert "feat($markdown): cache parser (#1359)"
Browse files Browse the repository at this point in the history
This reverts commit f04adbf.
  • Loading branch information
ulivz committed May 12, 2019
1 parent fbbd677 commit 04c2f2e
Show file tree
Hide file tree
Showing 3 changed files with 17 additions and 24 deletions.
22 changes: 16 additions & 6 deletions packages/@vuepress/markdown-loader/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -6,10 +6,11 @@

const { EventEmitter } = require('events')
const { getOptions } = require('loader-utils')
const { fs, path, parseFrontmatter, inferTitle, extractHeaders } = require('@vuepress/shared-utils')
const { fs, path, hash, parseFrontmatter, inferTitle, extractHeaders } = require('@vuepress/shared-utils')
const LRU = require('lru-cache')
const md = require('@vuepress/markdown')

const cache = new LRU({ max: 1000 })
const devCache = new LRU({ max: 1000 })

/**
Expand All @@ -31,18 +32,26 @@ module.exports = function (src) {
// vue-loader, and will be applied on the same file multiple times when
// selecting the individual blocks.
const file = this.resourcePath
const { content, data } = parseFrontmatter(src)
const key = hash(file + src)
const cached = cache.get(key)
if (cached && (isProd || /\?vue/.test(this.resourceQuery))) {
return cached
}

const frontmatter = parseFrontmatter(src)
const content = frontmatter.content

if (!isProd && !isServer) {
const inferredTitle = inferTitle(data, content)
const inferredTitle = inferTitle(frontmatter.data, frontmatter.content)
const headers = extractHeaders(content, ['h2', 'h3'], markdown)
delete frontmatter.content

// diff frontmatter and title, since they are not going to be part of the
// returned component, changes in frontmatter do not trigger proper updates
const cachedData = devCache.get(file)
if (cachedData && (
cachedData.inferredTitle !== inferredTitle
|| JSON.stringify(cachedData.frontmatterData) !== JSON.stringify(data)
|| JSON.stringify(cachedData.frontmatterData) !== JSON.stringify(frontmatter.data)
|| headersChanged(cachedData.headers, headers)
)) {
// frontmatter changed... need to do a full reload
Expand All @@ -51,7 +60,7 @@ module.exports = function (src) {

devCache.set(file, {
headers,
frontmatterData: data,
frontmatterData: frontmatter.data,
inferredTitle
})
}
Expand All @@ -64,7 +73,7 @@ module.exports = function (src) {
dataBlockString
} = markdown.render(content, {
loader,
frontmatter: data,
frontmatter: frontmatter.data,
relativePath: path.relative(sourceDir, file).replace(/\\/g, '/')
})

Expand Down Expand Up @@ -105,6 +114,7 @@ module.exports = function (src) {
+ (hoistedTags || []).join('\n')
+ `\n${dataBlockString}\n`
)
cache.set(key, res)
return res
}

Expand Down
18 changes: 1 addition & 17 deletions packages/@vuepress/markdown/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,6 @@
*/

const Config = require('markdown-it-chain')
const LRUCache = require('lru-cache')
const highlight = require('./lib/highlight')
const { PLUGINS, REQUIRED_PLUGINS } = require('./lib/constant')
const highlightLinesPlugin = require('./lib/highlightLines')
Expand All @@ -21,7 +20,7 @@ const tocPlugin = require('markdown-it-table-of-contents')
const {
slugify: _slugify,
parseHeaders,
logger, chalk, hash, normalizeConfig,
logger, chalk, normalizeConfig,
moduleResolver: { getMarkdownItResolver }
} = require('@vuepress/shared-utils')

Expand Down Expand Up @@ -124,21 +123,6 @@ module.exports = (markdown = {}) => {

afterInstantiate && afterInstantiate(md)

// override parse to allow cache
const parse = md.parse
const cache = new LRUCache({ max: 1000 })
md.parse = (src, env) => {
const key = hash(src + env.relativePath)
const cached = cache.get(key)
if (cached) {
return cached
} else {
const tokens = parse.call(md, src, env)
cache.set(key, tokens)
return tokens
}
}

module.exports.dataReturnable(md)

// expose slugify
Expand Down
1 change: 0 additions & 1 deletion packages/@vuepress/markdown/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -20,7 +20,6 @@
],
"dependencies": {
"@vuepress/shared-utils": "^1.0.0-alpha.47",
"lru-cache": "^5.1.1",
"markdown-it": "^8.4.1",
"markdown-it-anchor": "^5.0.2",
"markdown-it-chain": "^1.3.0",
Expand Down

0 comments on commit 04c2f2e

Please sign in to comment.