Skip to content

Commit

Permalink
wip: handle config hmr
Browse files Browse the repository at this point in the history
  • Loading branch information
yyx990803 committed Dec 28, 2020
1 parent bf8fd3a commit 084c7de
Show file tree
Hide file tree
Showing 6 changed files with 18 additions and 64 deletions.
2 changes: 1 addition & 1 deletion src/client/app/composables/siteData.ts
Original file line number Diff line number Diff line change
Expand Up @@ -16,7 +16,7 @@ function parse(data: string): SiteData {

// hmr
if (import.meta.hot) {
import.meta.hot!.accept('/@siteData', (m) => {
import.meta.hot.accept('/@siteData', (m) => {
siteDataRef.value = parse(m.default)
})
}
7 changes: 2 additions & 5 deletions src/client/theme-default/components/LastUpdated.vue
Original file line number Diff line number Diff line change
Expand Up @@ -12,8 +12,6 @@ import { useSiteDataByRoute, usePageData } from 'vitepress'
const site = useSiteDataByRoute()
const page = usePageData()
const datetime = ref('')
const hasLastUpdated = computed(() => {
const lu = site.value.themeConfig.lastUpdated
Expand All @@ -22,12 +20,11 @@ const hasLastUpdated = computed(() => {
const prefix = computed(() => {
const p = site.value.themeConfig.lastUpdated
return p === true ? 'Last Updated' : p
})
onMounted(() => {
datetime.value = new Date(page.value.lastUpdated).toLocaleString('en-US')
const datetime = computed(() => {
return new Date(page.value.lastUpdated).toLocaleString('en-US')
})
</script>

Expand Down
8 changes: 1 addition & 7 deletions src/node/cli.ts
Original file line number Diff line number Diff line change
Expand Up @@ -15,13 +15,7 @@ if (root) {

if (!command || command === 'dev') {
createServer(root, argv)
.then((server) => {
return server.listen().then(() => {
console.log(
`listening at http://localhost:${server.config.server.port}`
)
})
})
.then((server) => server.listen())
.catch((err) => {
console.error(chalk.red(`failed to start server. error:\n`), err)
process.exit(1)
Expand Down
46 changes: 9 additions & 37 deletions src/node/markdownToVue.ts
Original file line number Diff line number Diff line change
Expand Up @@ -8,12 +8,7 @@ import { PageData, HeadConfig } from '../../types/shared'
import slash from 'slash'

const debug = require('debug')('vitepress:md')
const cache = new LRUCache<string, MarkdownCompileCachedResult>({ max: 1024 })

interface MarkdownCompileCachedResult extends MarkdownCompileResult {
tagsWithPageData: string
tagsWithoutPageData: string
}
const cache = new LRUCache<string, MarkdownCompileResult>({ max: 1024 })

interface MarkdownCompileResult {
vueSrc: string
Expand All @@ -26,26 +21,20 @@ export function createMarkdownToVueRenderFn(
) {
const md = createMarkdownRenderer(options)

return (
src: string,
file: string,
injectData = true
): MarkdownCompileResult => {
return (src: string, file: string): MarkdownCompileResult => {
const relativePath = slash(path.relative(root, file))

const cached = cache.get(src)
if (cached) {
debug(`[cache hit] ${relativePath}`)
return pickResult(cached, injectData)
return cached
}

const start = Date.now()

const { content, data: frontmatter } = matter(src)
const { html, data } = md.render(content)

const vueSrc = `\n<template><div>${html}</div></template>`

// TODO validate data.links?
const pageData: PageData = {
title: inferTitle(frontmatter, content),
Expand All @@ -54,38 +43,21 @@ export function createMarkdownToVueRenderFn(
headers: data.headers,
relativePath,
// TODO use git timestamp?
lastUpdated: fs.statSync(file).mtimeMs
lastUpdated: Math.round(fs.statSync(file).mtimeMs)
}

const tagsWithPageData = genPageDataCode(
data.hoistedTags || [],
pageData
).join('\n')

const tagsWithoutPageData = (data.hoistedTags || []).join('\n')
const vueSrc =
genPageDataCode(data.hoistedTags || [], pageData).join('\n') +
`\n<template><div>${html}</div></template>`

debug(`[render] ${file} in ${Date.now() - start}ms.`)

const result = {
vueSrc,
pageData,
tagsWithPageData,
tagsWithoutPageData
pageData
}
cache.set(src, result)
return pickResult(result, injectData)
}
}

function pickResult(
res: MarkdownCompileCachedResult,
injectData: boolean
): MarkdownCompileResult {
return {
vueSrc:
res.vueSrc +
(injectData ? res.tagsWithPageData : res.tagsWithoutPageData),
pageData: res.pageData
return result
}
}

Expand Down
17 changes: 4 additions & 13 deletions src/node/plugin.ts
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,6 @@ export function createVitePressPlugin(
})

let siteData = initialSiteData
let stringifiedData = JSON.stringify(JSON.stringify(initialSiteData))

const vitePressPlugin: Plugin = {
name: 'vitepress',
Expand All @@ -37,7 +36,7 @@ export function createVitePressPlugin(

load(id) {
if (id === SITE_DATA_REQUEST_PATH) {
return `export default ${stringifiedData}`
return `export default ${JSON.stringify(JSON.stringify(siteData))}`
}
},

Expand All @@ -62,30 +61,22 @@ export function createVitePressPlugin(
},

async handleHotUpdate(file, mods, read, server) {
// handle config hmr
if (file === configPath) {
const newData = await resolveSiteData(root)
stringifiedData = JSON.stringify(JSON.stringify(newData))
if (newData.base !== siteData.base) {
console.warn(
`[vitepress]: config.base has changed. Please restart the dev server.`
)
}
siteData = newData
return
return [server.moduleGraph.getModuleById(SITE_DATA_REQUEST_PATH)!]
}

// hot reload .md files as .vue files
if (file.endsWith('.md')) {
const content = await read()
const { pageData, vueSrc } = markdownToVue(
content.toString(),
file,
// do not inject pageData on HMR
// it leads to plugin-vue to think <script> has changed and reloads
// the component instead of re-rendering.
// pageData needs separate HMR logic anyway (see below)
false
)
const { pageData, vueSrc } = markdownToVue(content, file)

// notify the client to update page data
server.ws.send({
Expand Down
2 changes: 1 addition & 1 deletion src/node/server.ts
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,7 @@ export async function createServer(

return createViteServer({
root,
logLevel: 'warn',
// logLevel: 'warn',
plugins: createVitePressPlugin(root, config),
server: serverOptions
})
Expand Down

0 comments on commit 084c7de

Please sign in to comment.