refactor: improve error message on encountering dead links

fixes #2281
closes #2307
closes #2314

Co-authored-by: jd-solanki <jdsolanki0001@gmail.com>
Co-authored-by: Christian Georgi <christian.georgi@sap.com>
pull/2320/head
Divyansh Singh 2 years ago
parent e36101c9ec
commit ae041448aa

@ -3,7 +3,6 @@ import _debug from 'debug'
import fs from 'fs'
import { LRUCache } from 'lru-cache'
import path from 'path'
import c from 'picocolors'
import type { SiteConfig } from './config'
import {
createMarkdownRenderer,
@ -26,7 +25,7 @@ const includesRE = /<!--\s*@include:\s*(.*?)\s*-->/g
export interface MarkdownCompileResult {
vueSrc: string
pageData: PageData
deadLinks: string[]
deadLinks: { url: string; file: string }[]
includes: string[]
}
@ -115,18 +114,9 @@ export async function createMarkdownToVueRenderFn(
} = env
// validate data.links
const deadLinks: string[] = []
const deadLinks: MarkdownCompileResult['deadLinks'] = []
const recordDeadLink = (url: string) => {
;(siteConfig?.logger ?? console).warn(
c.yellow(
`\n(!) Found dead link ${c.cyan(url)} in file ${c.white(
c.dim(file)
)}\nIf it is intended, you can use:\n ${c.cyan(
`<a href="${url}" target="_blank" rel="noreferrer">${url}</a>`
)}`
)
)
deadLinks.push(url)
deadLinks.push({ url, file: path.relative(srcDir, fileOrig) })
}
function shouldIgnoreDeadLink(url: string) {

@ -15,7 +15,11 @@ import {
resolveAliases
} from './alias'
import { resolveUserConfig, resolvePages, type SiteConfig } from './config'
import { clearCache, createMarkdownToVueRenderFn } from './markdownToVue'
import {
clearCache,
createMarkdownToVueRenderFn,
type MarkdownCompileResult
} from './markdownToVue'
import { slash, type PageDataPayload } from './shared'
import { staticDataPlugin } from './plugins/staticDataPlugin'
import { webFontsPlugin } from './plugins/webFontsPlugin'
@ -94,7 +98,7 @@ export async function createVitePressPlugin(
}
let siteData = site
let hasDeadLinks = false
let allDeadLinks: MarkdownCompileResult['deadLinks'] = []
let config: ResolvedConfig
const vitePressPlugin: Plugin = {
@ -184,9 +188,7 @@ export async function createVitePressPlugin(
id,
config.publicDir
)
if (deadLinks.length) {
hasDeadLinks = true
}
allDeadLinks.push(...deadLinks)
if (includes.length) {
includes.forEach((i) => {
this.addWatchFile(i)
@ -197,8 +199,22 @@ export async function createVitePressPlugin(
},
renderStart() {
if (hasDeadLinks) {
throw new Error(`One or more pages contain dead links.`)
if (allDeadLinks.length > 0) {
allDeadLinks.forEach(({ url, file }, i) => {
siteConfig.logger.warn(
c.yellow(
`${i === 0 ? '\n\n' : ''}(!) Found dead link ${c.cyan(
url
)} in file ${c.white(c.dim(file))}`
)
)
})
siteConfig.logger.info(
c.cyan(
'\nIf this is expected, you can disable this check via config. Refer: https://vitepress.dev/reference/site-config#ignoredeadlinks\n'
)
)
throw new Error(`${allDeadLinks.length} dead link(s) found.`)
}
},

Loading…
Cancel
Save