Urara-Blog/node_modules/.pnpm-store/v3/files/9f/2fc8039ac02af0dc0aa534fefd9d535abbb5e8e51a902f4f6efff730528ca0a9cdb878d4140f9b70c7142c8fa9dbfa00136545be58b27a29f2061bd0746474
2022-08-14 01:14:53 +08:00

47 lines
1.3 KiB
Text

import {decodeNamedCharacterReference} from 'decode-named-character-reference'
import {decodeNumericCharacterReference} from 'micromark-util-decode-numeric-character-reference'
import {codes} from 'micromark-util-symbol/codes.js'
import {constants} from 'micromark-util-symbol/constants.js'
const characterEscapeOrReference =
/\\([!-/:-@[-`{-~])|&(#(?:\d{1,7}|x[\da-f]{1,6})|[\da-z]{1,31});/gi
/**
* Utility to decode markdown strings (which occur in places such as fenced
* code info strings, destinations, labels, and titles).
* The “string” content type allows character escapes and -references.
* This decodes those.
*
* @param {string} value
* @returns {string}
*/
export function decodeString(value) {
return value.replace(characterEscapeOrReference, decode)
}
/**
* @param {string} $0
* @param {string} $1
* @param {string} $2
* @returns {string}
*/
function decode($0, $1, $2) {
if ($1) {
// Escape.
return $1
}
// Reference.
const head = $2.charCodeAt(0)
if (head === codes.numberSign) {
const head = $2.charCodeAt(1)
const hex = head === codes.lowercaseX || head === codes.uppercaseX
return decodeNumericCharacterReference(
$2.slice(hex ? 2 : 1),
hex ? constants.numericBaseHexadecimal : constants.numericBaseDecimal
)
}
return decodeNamedCharacterReference($2) || $0
}