renovate/lib/util/markdown.ts
Maron 4de1df3a6c
fix: fails to massage pnpm release notes (#17466)
Co-authored-by: Rhys Arkins <rhys@arkins.net>
2022-08-31 07:39:35 +00:00

44 lines
1.5 KiB
TypeScript

import remark from 'remark';
import github from 'remark-github';
import { regEx } from './regex';
// Generic replacements/link-breakers
export function sanitizeMarkdown(markdown: string): string {
let res = markdown;
// Put a zero width space after every # followed by a digit
res = res.replace(regEx(/#(\d)/gi), '#&#8203;$1');
// Put a zero width space after every @ symbol to prevent unintended hyperlinking
res = res.replace(regEx(/@/g), '@&#8203;');
res = res.replace(regEx(/(`\[?@)&#8203;/g), '$1');
res = res.replace(regEx(/([a-z]@)&#8203;/gi), '$1');
res = res.replace(regEx(/\/compare\/@&#8203;/g), '/compare/@');
res = res.replace(regEx(/(\(https:\/\/[^)]*?)\.\.\.@&#8203;/g), '$1...@');
res = res.replace(regEx(/([\s(])#(\d+)([)\s]?)/g), '$1#&#8203;$2$3');
// convert escaped backticks back to `
const backTickRe = regEx(/&#x60;([^/]*?)&#x60;/g);
res = res.replace(backTickRe, '`$1`');
res = res.replace(regEx(/`#&#8203;(\d+)`/g), '`#$1`');
res = res.replace(
regEx(/(?<before>[^\n]\n)(?<title>#.*)/g),
'$<before>\n$<title>'
);
return res;
}
/**
*
* @param content content to process
* @param options github options
* @returns linkified content
*/
export async function linkify(
content: string,
options: github.RemarkGithubOptions
): Promise<string> {
// https://github.com/syntax-tree/mdast-util-to-markdown#optionsbullet
const output = await remark()
.use({ settings: { bullet: '-' } })
.use(github, { mentionStrong: false, ...options })
.process(content);
return output.toString();
}