From 83354b2b88218090988dd6e526b0a2505b57e0f1 Mon Sep 17 00:00:00 2001 From: RaindropsSys Date: Thu, 6 Apr 2023 22:18:28 +0200 Subject: Updated 5 files and added 1110 files (automated) --- .../addressbook/node_modules/cheerio/lib/parse.js | 78 ++++++++++++++++++++++ 1 file changed, 78 insertions(+) create mode 100644 includes/external/addressbook/node_modules/cheerio/lib/parse.js (limited to 'includes/external/addressbook/node_modules/cheerio/lib/parse.js') diff --git a/includes/external/addressbook/node_modules/cheerio/lib/parse.js b/includes/external/addressbook/node_modules/cheerio/lib/parse.js new file mode 100644 index 0000000..f4c4707 --- /dev/null +++ b/includes/external/addressbook/node_modules/cheerio/lib/parse.js @@ -0,0 +1,78 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +exports.update = exports.getParse = void 0; +var domutils_1 = require("domutils"); +var domhandler_1 = require("domhandler"); +/** + * Get the parse function with options. + * + * @param parser - The parser function. + * @returns The parse function with options. + */ +function getParse(parser) { + /** + * Parse a HTML string or a node. + * + * @param content - The HTML string or node. + * @param options - The parser options. + * @param isDocument - If `content` is a document. + * @param context - The context node in the DOM tree. + * @returns The parsed document node. + */ + return function parse(content, options, isDocument, context) { + if (typeof Buffer !== 'undefined' && Buffer.isBuffer(content)) { + content = content.toString(); + } + if (typeof content === 'string') { + return parser(content, options, isDocument, context); + } + var doc = content; + if (!Array.isArray(doc) && (0, domhandler_1.isDocument)(doc)) { + // If `doc` is already a root, just return it + return doc; + } + // Add conent to new root element + var root = new domhandler_1.Document([]); + // Update the DOM using the root + update(doc, root); + return root; + }; +} +exports.getParse = getParse; +/** + * Update the dom structure, for one changed layer. + * + * @param newChilds - The new children. + * @param parent - The new parent. + * @returns The parent node. + */ +function update(newChilds, parent) { + // Normalize + var arr = Array.isArray(newChilds) ? newChilds : [newChilds]; + // Update parent + if (parent) { + parent.children = arr; + } + else { + parent = null; + } + // Update neighbors + for (var i = 0; i < arr.length; i++) { + var node = arr[i]; + // Cleanly remove existing nodes from their previous structures. + if (node.parent && node.parent.children !== arr) { + (0, domutils_1.removeElement)(node); + } + if (parent) { + node.prev = arr[i - 1] || null; + node.next = arr[i + 1] || null; + } + else { + node.prev = node.next = null; + } + node.parent = parent; + } + return parent; +} +exports.update = update; +//# sourceMappingURL=parse.js.map \ No newline at end of file -- cgit