aboutsummaryrefslogtreecommitdiffstats
path: root/vanilla/node_modules/entities/dist/esm/index.js
diff options
context:
space:
mode:
authorAdam Mathes <adam@adammathes.com>2026-02-13 21:34:48 -0800
committerAdam Mathes <adam@adammathes.com>2026-02-13 21:34:48 -0800
commit76cb9c2a39d477a64824a985ade40507e3bbade1 (patch)
tree41e997aa9c6f538d3a136af61dae9424db2005a9 /vanilla/node_modules/entities/dist/esm/index.js
parent819a39a21ac992b1393244a4c283bbb125208c69 (diff)
downloadneko-76cb9c2a39d477a64824a985ade40507e3bbade1.tar.gz
neko-76cb9c2a39d477a64824a985ade40507e3bbade1.tar.bz2
neko-76cb9c2a39d477a64824a985ade40507e3bbade1.zip
feat(vanilla): add testing infrastructure and tests (NK-wjnczv)
Diffstat (limited to 'vanilla/node_modules/entities/dist/esm/index.js')
-rw-r--r--vanilla/node_modules/entities/dist/esm/index.js107
1 files changed, 107 insertions, 0 deletions
diff --git a/vanilla/node_modules/entities/dist/esm/index.js b/vanilla/node_modules/entities/dist/esm/index.js
new file mode 100644
index 0000000..17576a8
--- /dev/null
+++ b/vanilla/node_modules/entities/dist/esm/index.js
@@ -0,0 +1,107 @@
+import { decodeXML, decodeHTML, DecodingMode } from "./decode.js";
+import { encodeHTML, encodeNonAsciiHTML } from "./encode.js";
+import { encodeXML, escapeUTF8, escapeAttribute, escapeText, } from "./escape.js";
+/** The level of entities to support. */
+export var EntityLevel;
+(function (EntityLevel) {
+ /** Support only XML entities. */
+ EntityLevel[EntityLevel["XML"] = 0] = "XML";
+ /** Support HTML entities, which are a superset of XML entities. */
+ EntityLevel[EntityLevel["HTML"] = 1] = "HTML";
+})(EntityLevel || (EntityLevel = {}));
+export var EncodingMode;
+(function (EncodingMode) {
+ /**
+ * The output is UTF-8 encoded. Only characters that need escaping within
+ * XML will be escaped.
+ */
+ EncodingMode[EncodingMode["UTF8"] = 0] = "UTF8";
+ /**
+ * The output consists only of ASCII characters. Characters that need
+ * escaping within HTML, and characters that aren't ASCII characters will
+ * be escaped.
+ */
+ EncodingMode[EncodingMode["ASCII"] = 1] = "ASCII";
+ /**
+ * Encode all characters that have an equivalent entity, as well as all
+ * characters that are not ASCII characters.
+ */
+ EncodingMode[EncodingMode["Extensive"] = 2] = "Extensive";
+ /**
+ * Encode all characters that have to be escaped in HTML attributes,
+ * following {@link https://html.spec.whatwg.org/multipage/parsing.html#escapingString}.
+ */
+ EncodingMode[EncodingMode["Attribute"] = 3] = "Attribute";
+ /**
+ * Encode all characters that have to be escaped in HTML text,
+ * following {@link https://html.spec.whatwg.org/multipage/parsing.html#escapingString}.
+ */
+ EncodingMode[EncodingMode["Text"] = 4] = "Text";
+})(EncodingMode || (EncodingMode = {}));
+/**
+ * Decodes a string with entities.
+ *
+ * @param input String to decode.
+ * @param options Decoding options.
+ */
+export function decode(input, options = EntityLevel.XML) {
+ const level = typeof options === "number" ? options : options.level;
+ if (level === EntityLevel.HTML) {
+ const mode = typeof options === "object" ? options.mode : undefined;
+ return decodeHTML(input, mode);
+ }
+ return decodeXML(input);
+}
+/**
+ * Decodes a string with entities. Does not allow missing trailing semicolons for entities.
+ *
+ * @param input String to decode.
+ * @param options Decoding options.
+ * @deprecated Use `decode` with the `mode` set to `Strict`.
+ */
+export function decodeStrict(input, options = EntityLevel.XML) {
+ var _a;
+ const normalizedOptions = typeof options === "number" ? { level: options } : options;
+ (_a = normalizedOptions.mode) !== null && _a !== void 0 ? _a : (normalizedOptions.mode = DecodingMode.Strict);
+ return decode(input, normalizedOptions);
+}
+/**
+ * Encodes a string with entities.
+ *
+ * @param input String to encode.
+ * @param options Encoding options.
+ */
+export function encode(input, options = EntityLevel.XML) {
+ const { mode = EncodingMode.Extensive, level = EntityLevel.XML } = typeof options === "number" ? { level: options } : options;
+ switch (mode) {
+ case EncodingMode.UTF8: {
+ return escapeUTF8(input);
+ }
+ case EncodingMode.Attribute: {
+ return escapeAttribute(input);
+ }
+ case EncodingMode.Text: {
+ return escapeText(input);
+ }
+ case EncodingMode.ASCII: {
+ return level === EntityLevel.HTML
+ ? encodeNonAsciiHTML(input)
+ : encodeXML(input);
+ }
+ // eslint-disable-next-line unicorn/no-useless-switch-case
+ case EncodingMode.Extensive:
+ default: {
+ return level === EntityLevel.HTML
+ ? encodeHTML(input)
+ : encodeXML(input);
+ }
+ }
+}
+export { encodeXML, escape, escapeUTF8, escapeAttribute, escapeText, } from "./escape.js";
+export { encodeHTML, encodeNonAsciiHTML,
+// Legacy aliases (deprecated)
+encodeHTML as encodeHTML4, encodeHTML as encodeHTML5, } from "./encode.js";
+export { EntityDecoder, DecodingMode, decodeXML, decodeHTML, decodeHTMLStrict, decodeHTMLAttribute,
+// Legacy aliases (deprecated)
+decodeHTML as decodeHTML4, decodeHTML as decodeHTML5, decodeHTMLStrict as decodeHTML4Strict, decodeHTMLStrict as decodeHTML5Strict, decodeXML as decodeXMLStrict, } from "./decode.js";
+//# sourceMappingURL=index.js.map \ No newline at end of file