122 lines
		
	
	
		
			4.2 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
		
		
			
		
	
	
			122 lines
		
	
	
		
			4.2 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
|  | "use strict"; | ||
|  | Object.defineProperty(exports, "__esModule", { value: true }); | ||
|  | exports.escapeText = exports.escapeAttribute = exports.escapeUTF8 = exports.escape = exports.encodeXML = exports.getCodePoint = exports.xmlReplacer = void 0; | ||
|  | exports.xmlReplacer = /["&'<>$\x80-\uFFFF]/g; | ||
|  | var xmlCodeMap = new Map([ | ||
|  |     [34, """], | ||
|  |     [38, "&"], | ||
|  |     [39, "'"], | ||
|  |     [60, "<"], | ||
|  |     [62, ">"], | ||
|  | ]); | ||
|  | // For compatibility with node < 4, we wrap `codePointAt`
 | ||
|  | exports.getCodePoint =  | ||
|  | // eslint-disable-next-line @typescript-eslint/no-unnecessary-condition
 | ||
|  | String.prototype.codePointAt != null | ||
|  |     ? function (str, index) { return str.codePointAt(index); } | ||
|  |     : // http://mathiasbynens.be/notes/javascript-encoding#surrogate-formulae
 | ||
|  |         function (c, index) { | ||
|  |             return (c.charCodeAt(index) & 0xfc00) === 0xd800 | ||
|  |                 ? (c.charCodeAt(index) - 0xd800) * 0x400 + | ||
|  |                     c.charCodeAt(index + 1) - | ||
|  |                     0xdc00 + | ||
|  |                     0x10000 | ||
|  |                 : c.charCodeAt(index); | ||
|  |         }; | ||
|  | /** | ||
|  |  * Encodes all non-ASCII characters, as well as characters not valid in XML | ||
|  |  * documents using XML entities. | ||
|  |  * | ||
|  |  * If a character has no equivalent entity, a | ||
|  |  * numeric hexadecimal reference (eg. `ü`) will be used. | ||
|  |  */ | ||
|  | function encodeXML(str) { | ||
|  |     var ret = ""; | ||
|  |     var lastIdx = 0; | ||
|  |     var match; | ||
|  |     while ((match = exports.xmlReplacer.exec(str)) !== null) { | ||
|  |         var i = match.index; | ||
|  |         var char = str.charCodeAt(i); | ||
|  |         var next = xmlCodeMap.get(char); | ||
|  |         if (next !== undefined) { | ||
|  |             ret += str.substring(lastIdx, i) + next; | ||
|  |             lastIdx = i + 1; | ||
|  |         } | ||
|  |         else { | ||
|  |             ret += "".concat(str.substring(lastIdx, i), "&#x").concat((0, exports.getCodePoint)(str, i).toString(16), ";"); | ||
|  |             // Increase by 1 if we have a surrogate pair
 | ||
|  |             lastIdx = exports.xmlReplacer.lastIndex += Number((char & 0xfc00) === 0xd800); | ||
|  |         } | ||
|  |     } | ||
|  |     return ret + str.substr(lastIdx); | ||
|  | } | ||
|  | exports.encodeXML = encodeXML; | ||
|  | /** | ||
|  |  * Encodes all non-ASCII characters, as well as characters not valid in XML | ||
|  |  * documents using numeric hexadecimal reference (eg. `ü`). | ||
|  |  * | ||
|  |  * Have a look at `escapeUTF8` if you want a more concise output at the expense | ||
|  |  * of reduced transportability. | ||
|  |  * | ||
|  |  * @param data String to escape. | ||
|  |  */ | ||
|  | exports.escape = encodeXML; | ||
|  | /** | ||
|  |  * Creates a function that escapes all characters matched by the given regular | ||
|  |  * expression using the given map of characters to escape to their entities. | ||
|  |  * | ||
|  |  * @param regex Regular expression to match characters to escape. | ||
|  |  * @param map Map of characters to escape to their entities. | ||
|  |  * | ||
|  |  * @returns Function that escapes all characters matched by the given regular | ||
|  |  * expression using the given map of characters to escape to their entities. | ||
|  |  */ | ||
|  | function getEscaper(regex, map) { | ||
|  |     return function escape(data) { | ||
|  |         var match; | ||
|  |         var lastIdx = 0; | ||
|  |         var result = ""; | ||
|  |         while ((match = regex.exec(data))) { | ||
|  |             if (lastIdx !== match.index) { | ||
|  |                 result += data.substring(lastIdx, match.index); | ||
|  |             } | ||
|  |             // We know that this character will be in the map.
 | ||
|  |             result += map.get(match[0].charCodeAt(0)); | ||
|  |             // Every match will be of length 1
 | ||
|  |             lastIdx = match.index + 1; | ||
|  |         } | ||
|  |         return result + data.substring(lastIdx); | ||
|  |     }; | ||
|  | } | ||
|  | /** | ||
|  |  * Encodes all characters not valid in XML documents using XML entities. | ||
|  |  * | ||
|  |  * Note that the output will be character-set dependent. | ||
|  |  * | ||
|  |  * @param data String to escape. | ||
|  |  */ | ||
|  | exports.escapeUTF8 = getEscaper(/[&<>'"]/g, xmlCodeMap); | ||
|  | /** | ||
|  |  * Encodes all characters that have to be escaped in HTML attributes, | ||
|  |  * following {@link https://html.spec.whatwg.org/multipage/parsing.html#escapingString}.
 | ||
|  |  * | ||
|  |  * @param data String to escape. | ||
|  |  */ | ||
|  | exports.escapeAttribute = getEscaper(/["&\u00A0]/g, new Map([ | ||
|  |     [34, """], | ||
|  |     [38, "&"], | ||
|  |     [160, " "], | ||
|  | ])); | ||
|  | /** | ||
|  |  * Encodes all characters that have to be escaped in HTML text, | ||
|  |  * following {@link https://html.spec.whatwg.org/multipage/parsing.html#escapingString}.
 | ||
|  |  * | ||
|  |  * @param data String to escape. | ||
|  |  */ | ||
|  | exports.escapeText = getEscaper(/[&<>\u00A0]/g, new Map([ | ||
|  |     [38, "&"], | ||
|  |     [60, "<"], | ||
|  |     [62, ">"], | ||
|  |     [160, " "], | ||
|  | ])); | ||
|  | //# sourceMappingURL=escape.js.map
 |