From 70a64aefe060fdd105819618de64a922e3824b51 Mon Sep 17 00:00:00 2001 From: Sune Simonsen Date: Tue, 3 Apr 2018 14:10:48 +0200 Subject: [PATCH] 4.5.0 --- package.json | 2 +- unexpected-dom.js | 14 ++++++++++---- unexpected-dom.min.js | 4 ++-- 3 files changed, 13 insertions(+), 7 deletions(-) diff --git a/package.json b/package.json index 30ce60f4..066c9b28 100644 --- a/package.json +++ b/package.json @@ -1,6 +1,6 @@ { "name": "unexpected-dom", - "version": "4.4.2", + "version": "4.5.0", "description": "DOM plugin for the unexpected assertion libary", "main": "lib/index.js", "files": [ diff --git a/unexpected-dom.js b/unexpected-dom.js index b586b77c..1df7bf0c 100644 --- a/unexpected-dom.js +++ b/unexpected-dom.js @@ -746,9 +746,15 @@ module.exports = { return { name: node.nodeName }; } else if (node.nodeType === 1) { // DOMElement - var result = { - name: isHtml ? node.nodeName.toLowerCase() : node.nodeName - }; + var name = isHtml ? node.nodeName.toLowerCase() : node.nodeName; + + if (name === 'ignore') { + // Ignore subtree + return {}; + } + + var result = { name: name }; + if (node.attributes) { result.attributes = {}; for (var i = 0; i < node.attributes.length; i += 1) { @@ -2544,4 +2550,4 @@ Prism.languages.js = Prism.languages.javascript; },{}]},{},[1])(1) }); -//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["node_modules/browser-pack/_prelude.js","lib/index.js","lib/matchesSelector.js","node_modules/magicpen-prism/lib/magicPenPrism.js","node_modules/magicpen-prism/package.json","node_modules/prismjs/components/prism-csp.js","node_modules/prismjs/components/prism-graphql.js","node_modules/prismjs/prism.js"],"names":[],"mappings":"AAAA;ACAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC75CA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;ACrBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;ACnHA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACjEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACxBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;ACvBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","file":"generated.js","sourceRoot":"","sourcesContent":["(function(){function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require==\"function\"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error(\"Cannot find module '\"+o+\"'\");throw f.code=\"MODULE_NOT_FOUND\",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require==\"function\"&&require;for(var o=0;o<r.length;o++)s(r[o]);return s}return e})()","/*global DOMParser*/\nvar matchesSelector = require('./matchesSelector');\n\nfunction parseHtml(str, isFragment, assertionNameForErrorMessage) {\n  if (isFragment) {\n    str = '<html><head></head><body>' + str + '</body></html>';\n  }\n  var htmlDocument;\n  if (typeof DOMParser !== 'undefined') {\n    htmlDocument = new DOMParser().parseFromString(str, 'text/html');\n  } else if (\n    typeof document !== 'undefined' &&\n    document.implementation &&\n    document.implementation.createHTMLDocument\n  ) {\n    htmlDocument = document.implementation.createHTMLDocument('');\n    htmlDocument.open();\n    htmlDocument.write(str);\n    htmlDocument.close();\n  } else {\n    var jsdom;\n    try {\n      jsdom = require('' + 'jsdom');\n    } catch (err) {\n      throw new Error(\n        'unexpected-dom' +\n          (assertionNameForErrorMessage\n            ? ' (' + assertionNameForErrorMessage + ')'\n            : '') +\n          ': Running outside a browser, but could not find the `jsdom` module. Please npm install jsdom to make this work.'\n      );\n    }\n    if (jsdom.JSDOM) {\n      htmlDocument = new jsdom.JSDOM(str).window.document;\n    } else {\n      htmlDocument = jsdom.jsdom(str);\n    }\n  }\n  if (isFragment) {\n    var body = htmlDocument.body;\n    var documentFragment = htmlDocument.createDocumentFragment();\n    if (body) {\n      for (var i = 0; i < body.childNodes.length; i += 1) {\n        documentFragment.appendChild(body.childNodes[i].cloneNode(true));\n      }\n    }\n    return documentFragment;\n  } else {\n    return htmlDocument;\n  }\n}\n\nfunction parseXml(str, assertionNameForErrorMessage) {\n  if (typeof DOMParser !== 'undefined') {\n    return new DOMParser().parseFromString(str, 'text/xml');\n  } else {\n    var jsdom;\n    try {\n      jsdom = require('' + 'jsdom');\n    } catch (err) {\n      throw new Error(\n        'unexpected-dom' +\n          (assertionNameForErrorMessage\n            ? ' (' + assertionNameForErrorMessage + ')'\n            : '') +\n          ': Running outside a browser (or in a browser without DOMParser), but could not find the `jsdom` module. Please npm install jsdom to make this work.'\n      );\n    }\n    if (jsdom.JSDOM) {\n      return new jsdom.JSDOM(str, { contentType: 'text/xml' }).window.document;\n    } else {\n      return jsdom.jsdom(str, { parsingMode: 'xml' });\n    }\n  }\n}\n\n// From html-minifier\nvar enumeratedAttributeValues = {\n  draggable: ['true', 'false'] // defaults to 'auto'\n};\n\nfunction isBooleanAttribute(attrName, attrValue) {\n  var isSimpleBoolean = /^(?:allowfullscreen|async|autofocus|autoplay|checked|compact|controls|declare|default|defaultchecked|defaultmuted|defaultselected|defer|disabled|enabled|formnovalidate|hidden|indeterminate|inert|ismap|itemscope|loop|multiple|muted|nohref|noresize|noshade|novalidate|nowrap|open|pauseonexit|readonly|required|reversed|scoped|seamless|selected|sortable|spellcheck|truespeed|typemustmatch|visible)$/i.test(\n    attrName\n  );\n  if (isSimpleBoolean) {\n    return true;\n  }\n\n  var attrValueEnumeration = enumeratedAttributeValues[attrName.toLowerCase()];\n  if (!attrValueEnumeration) {\n    return false;\n  } else {\n    return attrValueEnumeration.indexOf(attrValue.toLowerCase()) === -1;\n  }\n}\n\nfunction styleStringToObject(str) {\n  var styles = {};\n\n  str.split(';').forEach(function(rule) {\n    var tuple = rule.split(':').map(function(part) {\n      return part.trim();\n    });\n\n    // Guard against empty touples\n    if (tuple[0] && tuple[1]) {\n      styles[tuple[0]] = tuple[1];\n    }\n  });\n\n  return styles;\n}\n\nfunction getClassNamesFromAttributeValue(attributeValue) {\n  if (attributeValue === null) {\n    return '';\n  }\n\n  var classNames = attributeValue.split(/\\s+/);\n  if (classNames.length === 1 && classNames[0] === '') {\n    classNames.pop();\n  }\n  return classNames;\n}\n\nfunction isInsideHtmlDocument(node) {\n  var ownerDocument;\n  if (node.nodeType === 9 && node.documentElement && node.implementation) {\n    ownerDocument = node;\n  } else {\n    ownerDocument = node.ownerDocument;\n  }\n  if (ownerDocument.contentType) {\n    return ownerDocument.contentType === 'text/html';\n  } else {\n    return ownerDocument.toString() === '[object HTMLDocument]';\n  }\n}\n\nfunction getAttributes(element) {\n  var isHtml = isInsideHtmlDocument(element);\n  var attrs = element.attributes;\n  var result = {};\n\n  for (var i = 0; i < attrs.length; i += 1) {\n    if (attrs[i].name === 'class') {\n      result[attrs[i].name] =\n        (attrs[i].value && attrs[i].value.split(' ')) || [];\n    } else if (attrs[i].name === 'style') {\n      result[attrs[i].name] = styleStringToObject(attrs[i].value);\n    } else {\n      result[attrs[i].name] =\n        isHtml && isBooleanAttribute(attrs[i].name)\n          ? true\n          : attrs[i].value || '';\n    }\n  }\n\n  return result;\n}\n\nfunction getCanonicalAttributes(element) {\n  var attrs = getAttributes(element);\n  var result = {};\n\n  Object.keys(attrs)\n    .sort()\n    .forEach(function(key) {\n      result[key] = attrs[key];\n    });\n\n  return result;\n}\n\nfunction entitify(value) {\n  return String(value)\n    .replace(/&/g, '&amp;')\n    .replace(/\"/g, '&quot;')\n    .replace(/</g, '&lt;');\n}\n\nfunction isVoidElement(elementName) {\n  return /(?:area|base|br|col|embed|hr|img|input|keygen|link|menuitem|meta|param|source|track|wbr)/i.test(\n    elementName\n  );\n}\n\nfunction writeAttributeToMagicPen(output, attributeName, value, isHtml) {\n  output.prismAttrName(attributeName);\n  if (!isHtml || !isBooleanAttribute(attributeName)) {\n    if (attributeName === 'class') {\n      value = value.join(' ');\n    } else if (attributeName === 'style') {\n      value = Object.keys(value)\n        .map(function(cssProp) {\n          return cssProp + ': ' + value[cssProp];\n        })\n        .join('; ');\n    }\n    output\n      .prismPunctuation('=\"')\n      .prismAttrValue(entitify(value))\n      .prismPunctuation('\"');\n  }\n}\n\nfunction stringifyAttribute(attributeName, value) {\n  if (isBooleanAttribute(attributeName)) {\n    return attributeName;\n  } else if (attributeName === 'class') {\n    return 'class=\"' + value.join(' ') + '\"'; // FIXME: entitify\n  } else if (attributeName === 'style') {\n    return (\n      'style=\"' +\n      Object.keys(value)\n        .map(function(cssProp) {\n          return [cssProp, value[cssProp]].join(': '); // FIXME: entitify\n        })\n        .join('; ') +\n      '\"'\n    );\n  } else {\n    return attributeName + '=\"' + entitify(value) + '\"';\n  }\n}\n\nfunction stringifyStartTag(element) {\n  var elementName =\n    element.ownerDocument.contentType === 'text/html'\n      ? element.nodeName.toLowerCase()\n      : element.nodeName;\n  var str = '<' + elementName;\n  var attrs = getCanonicalAttributes(element);\n\n  Object.keys(attrs).forEach(function(key) {\n    str += ' ' + stringifyAttribute(key, attrs[key]);\n  });\n\n  str += '>';\n  return str;\n}\n\nfunction stringifyEndTag(element) {\n  var isHtml = isInsideHtmlDocument(element);\n  var elementName = isHtml ? element.nodeName.toLowerCase() : element.nodeName;\n  if (isHtml && isVoidElement(elementName) && element.childNodes.length === 0) {\n    return '';\n  } else {\n    return '</' + elementName + '>';\n  }\n}\n\nmodule.exports = {\n  name: 'unexpected-dom',\n  installInto: function(expect) {\n    expect = expect.child();\n    expect.use(require('magicpen-prism'));\n    var topLevelExpect = expect;\n    expect.exportType({\n      name: 'DOMNode',\n      base: 'object',\n      identify: function(obj) {\n        return (\n          obj &&\n          obj.nodeName &&\n          [2, 3, 4, 5, 6, 7, 10, 11, 12].indexOf(obj.nodeType) > -1\n        );\n      },\n      equal: function(a, b) {\n        return a.nodeValue === b.nodeValue;\n      },\n      inspect: function(element, depth, output) {\n        return output.code(\n          element.nodeName + ' \"' + element.nodeValue + '\"',\n          'prism-string'\n        );\n      }\n    });\n\n    expect.exportType({\n      name: 'DOMComment',\n      base: 'DOMNode',\n      identify: function(obj) {\n        return obj && typeof obj.nodeType === 'number' && obj.nodeType === 8;\n      },\n      equal: function(a, b) {\n        return a.nodeValue === b.nodeValue;\n      },\n      inspect: function(element, depth, output) {\n        return output.code('<!--' + element.nodeValue + '-->', 'html');\n      },\n      diff: function(actual, expected, output, diff, inspect, equal) {\n        var d = diff(\n          '<!--' + actual.nodeValue + '-->',\n          '<!--' + expected.nodeValue + '-->'\n        );\n        d.inline = true;\n        return d;\n      }\n    });\n\n    expect.exportType({\n      name: 'DOMTextNode',\n      base: 'DOMNode',\n      identify: function(obj) {\n        return obj && typeof obj.nodeType === 'number' && obj.nodeType === 3;\n      },\n      equal: function(a, b) {\n        return a.nodeValue === b.nodeValue;\n      },\n      inspect: function(element, depth, output) {\n        return output.code(entitify(element.nodeValue.trim()), 'html');\n      },\n      diff: function(actual, expected, output, diff, inspect, equal) {\n        var d = diff(actual.nodeValue, expected.nodeValue);\n        d.inline = true;\n        return d;\n      }\n    });\n\n    expect.exportType({\n      name: 'DOMNodeList',\n      base: 'array-like',\n      prefix: function(output) {\n        return output.text('NodeList[');\n      },\n      suffix: function(output) {\n        return output.text(']');\n      },\n      similar: function(a, b) {\n        // Figure out whether a and b are \"struturally similar\" so they can be diffed inline.\n        return (\n          a.nodeType === 1 && b.nodeType === 1 && a.nodeName === b.nodeName\n        );\n      },\n      identify: function(obj) {\n        return (\n          obj &&\n          typeof obj.length === 'number' &&\n          typeof obj.toString === 'function' &&\n          typeof obj.item === 'function' &&\n          // With jsdom 6+, nodeList.toString() comes out as '[object Object]', so fall back to the constructor name:\n          (obj.toString().indexOf('NodeList') !== -1 ||\n            (obj.constructor && obj.constructor.name === 'NodeList'))\n        );\n      }\n    });\n\n    // Fake type to make it possible to build 'to satisfy' diffs to be rendered inline:\n    expect.exportType({\n      name: 'attachedDOMNodeList',\n      base: 'DOMNodeList',\n      indent: false,\n      prefix: function(output) {\n        return output;\n      },\n      suffix: function(output) {\n        return output;\n      },\n      delimiter: function(output) {\n        return output;\n      },\n      identify: function(obj) {\n        return obj && obj._isAttachedDOMNodeList;\n      }\n    });\n\n    function makeAttachedDOMNodeList(domNodeList, contentType) {\n      var attachedDOMNodeList = [];\n      for (var i = 0; i < domNodeList.length; i += 1) {\n        attachedDOMNodeList.push(domNodeList[i]);\n      }\n      attachedDOMNodeList._isAttachedDOMNodeList = true;\n      attachedDOMNodeList.ownerDocument = { contentType: contentType };\n      return attachedDOMNodeList;\n    }\n\n    expect.exportType({\n      name: 'HTMLDocType',\n      base: 'DOMNode',\n      identify: function(obj) {\n        return (\n          obj &&\n          typeof obj.nodeType === 'number' &&\n          obj.nodeType === 10 &&\n          'publicId' in obj\n        );\n      },\n      inspect: function(doctype, depth, output, inspect) {\n        return output.code('<!DOCTYPE ' + doctype.name + '>', 'html');\n      },\n      equal: function(a, b) {\n        return a.toString() === b.toString();\n      },\n      diff: function(actual, expected, output, diff) {\n        var d = diff(\n          '<!DOCTYPE ' + actual.name + '>',\n          '<!DOCTYPE ' + expected.name + '>'\n        );\n        d.inline = true;\n        return d;\n      }\n    });\n\n    expect.exportType({\n      name: 'DOMDocument',\n      base: 'DOMNode',\n      identify: function(obj) {\n        return (\n          obj &&\n          typeof obj.nodeType === 'number' &&\n          obj.nodeType === 9 &&\n          obj.documentElement &&\n          obj.implementation\n        );\n      },\n      inspect: function(document, depth, output, inspect) {\n        for (var i = 0; i < document.childNodes.length; i += 1) {\n          output.append(inspect(document.childNodes[i]));\n        }\n        return output;\n      },\n      diff: function(actual, expected, output, diff, inspect, equal) {\n        output.inline = true;\n        output.append(\n          diff(\n            makeAttachedDOMNodeList(actual.childNodes),\n            makeAttachedDOMNodeList(expected.childNodes)\n          ).diff\n        );\n        return output;\n      }\n    });\n\n    expect.exportType({\n      name: 'HTMLDocument',\n      base: 'DOMDocument',\n      identify: function(obj) {\n        return this.baseType.identify(obj) && obj.contentType === 'text/html';\n      }\n    });\n\n    expect.exportType({\n      name: 'XMLDocument',\n      base: 'DOMDocument',\n      identify: function(obj) {\n        return (\n          this.baseType.identify(obj) &&\n          /^(?:application|text)\\/xml|\\+xml\\b/.test(obj.contentType)\n        );\n      },\n      inspect: function(document, depth, output, inspect) {\n        output.code('<?xml version=\"1.0\"?>', 'xml');\n        for (var i = 0; i < document.childNodes.length; i += 1) {\n          output.append(inspect(document.childNodes[i], depth - 1));\n        }\n        return output;\n      }\n    });\n\n    expect.exportType({\n      name: 'DOMDocumentFragment',\n      base: 'DOMNode',\n      identify: function(obj) {\n        return obj && obj.nodeType === 11; // In jsdom, documentFragment.toString() does not return [object DocumentFragment]\n      },\n      inspect: function(documentFragment, depth, output, inspect) {\n        return output\n          .text('DocumentFragment[')\n          .append(inspect(documentFragment.childNodes, depth))\n          .text(']');\n      },\n      diff: function(actual, expected, output, diff, inspect, equal) {\n        output.inline = true;\n        output.block(\n          diff(\n            makeAttachedDOMNodeList(actual.childNodes),\n            makeAttachedDOMNodeList(expected.childNodes)\n          ).diff\n        );\n        return output;\n      }\n    });\n\n    expect.exportType({\n      name: 'DOMElement',\n      base: 'DOMNode',\n      identify: function(obj) {\n        return (\n          obj &&\n          typeof obj.nodeType === 'number' &&\n          obj.nodeType === 1 &&\n          obj.nodeName &&\n          obj.attributes\n        );\n      },\n      equal: function(a, b, equal) {\n        var aIsHtml = isInsideHtmlDocument(a);\n        var bIsHtml = isInsideHtmlDocument(b);\n        return (\n          aIsHtml === bIsHtml &&\n          (aIsHtml\n            ? a.nodeName.toLowerCase() === b.nodeName.toLowerCase()\n            : a.nodeName === b.nodeName) &&\n          equal(getAttributes(a), getAttributes(b)) &&\n          equal(a.childNodes, b.childNodes)\n        );\n      },\n      inspect: function(element, depth, output, inspect) {\n        var elementName = element.nodeName.toLowerCase();\n        var startTag = stringifyStartTag(element);\n\n        output.code(startTag, 'html');\n        if (element.childNodes.length > 0) {\n          if (depth === 1) {\n            output.text('...');\n          } else {\n            var inspectedChildren = [];\n            if (elementName === 'script') {\n              var type = element.getAttribute('type');\n              if (!type || /javascript/.test(type)) {\n                type = 'javascript';\n              }\n              inspectedChildren.push(\n                output.clone().code(element.textContent, type)\n              );\n            } else if (elementName === 'style') {\n              inspectedChildren.push(\n                output\n                  .clone()\n                  .code(\n                    element.textContent,\n                    element.getAttribute('type') || 'text/css'\n                  )\n              );\n            } else {\n              for (var i = 0; i < element.childNodes.length; i += 1) {\n                inspectedChildren.push(inspect(element.childNodes[i]));\n              }\n            }\n\n            var width = startTag.length;\n            var multipleLines = inspectedChildren.some(function(o) {\n              var size = o.size();\n              width += size.width;\n              return width > 60 || o.height > 1;\n            });\n\n            if (multipleLines) {\n              output.nl().indentLines();\n\n              inspectedChildren.forEach(function(inspectedChild, index) {\n                output\n                  .i()\n                  .block(inspectedChild)\n                  .nl();\n              });\n\n              output.outdentLines();\n            } else {\n              inspectedChildren.forEach(function(inspectedChild, index) {\n                output.append(inspectedChild);\n              });\n            }\n          }\n        }\n        output.code(stringifyEndTag(element), 'html');\n        return output;\n      },\n      diffLimit: 512,\n      diff: function(actual, expected, output, diff, inspect, equal) {\n        var isHtml = isInsideHtmlDocument(actual);\n        output.inline = true;\n\n        if (Math.max(actual.length, expected.length) > this.diffLimit) {\n          output.jsComment('Diff suppressed due to size > ' + this.diffLimit);\n          return output;\n        }\n\n        var emptyElements =\n          actual.childNodes.length === 0 && expected.childNodes.length === 0;\n        var conflictingElement =\n          actual.nodeName.toLowerCase() !== expected.nodeName.toLowerCase() ||\n          !equal(getAttributes(actual), getAttributes(expected));\n\n        if (conflictingElement) {\n          var canContinueLine = true;\n          output.prismPunctuation('<').prismTag(actual.nodeName.toLowerCase());\n          if (\n            actual.nodeName.toLowerCase() !== expected.nodeName.toLowerCase()\n          ) {\n            output\n              .sp()\n              .annotationBlock(function() {\n                this.error('should be')\n                  .sp()\n                  .prismTag(expected.nodeName.toLowerCase());\n              })\n              .nl();\n            canContinueLine = false;\n          }\n          var actualAttributes = getAttributes(actual);\n          var expectedAttributes = getAttributes(expected);\n          Object.keys(actualAttributes).forEach(function(attributeName) {\n            output.sp(canContinueLine ? 1 : 2 + actual.nodeName.length);\n            writeAttributeToMagicPen(\n              output,\n              attributeName,\n              actualAttributes[attributeName],\n              isHtml\n            );\n            if (attributeName in expectedAttributes) {\n              if (\n                actualAttributes[attributeName] ===\n                expectedAttributes[attributeName]\n              ) {\n                canContinueLine = true;\n              } else {\n                output\n                  .sp()\n                  .annotationBlock(function() {\n                    this.error('should equal')\n                      .sp()\n                      .append(\n                        inspect(entitify(expectedAttributes[attributeName]))\n                      );\n                  })\n                  .nl();\n                canContinueLine = false;\n              }\n              delete expectedAttributes[attributeName];\n            } else {\n              output\n                .sp()\n                .annotationBlock(function() {\n                  this.error('should be removed');\n                })\n                .nl();\n              canContinueLine = false;\n            }\n          });\n          Object.keys(expectedAttributes).forEach(function(attributeName) {\n            output.sp(canContinueLine ? 1 : 2 + actual.nodeName.length);\n            output\n              .annotationBlock(function() {\n                this.error('missing').sp();\n                writeAttributeToMagicPen(\n                  this,\n                  attributeName,\n                  expectedAttributes[attributeName],\n                  isHtml\n                );\n              })\n              .nl();\n            canContinueLine = false;\n          });\n          output.prismPunctuation('>');\n        } else {\n          output.code(stringifyStartTag(actual), 'html');\n        }\n\n        if (!emptyElements) {\n          output\n            .nl()\n            .indentLines()\n            .i()\n            .block(\n              diff(\n                makeAttachedDOMNodeList(actual.childNodes),\n                makeAttachedDOMNodeList(expected.childNodes)\n              ).diff\n            )\n            .nl()\n            .outdentLines();\n        }\n\n        output.code(stringifyEndTag(actual), 'html');\n        return output;\n      }\n    });\n\n    expect.exportAssertion(\n      '<DOMElement> to have (class|classes) <array|string>',\n      function(expect, subject, value) {\n        return expect(subject, 'to have attributes', { class: value });\n      }\n    );\n\n    expect.exportAssertion(\n      '<DOMElement> to only have (class|classes) <array|string>',\n      function(expect, subject, value) {\n        return expect(subject, 'to have attributes', {\n          class: function(className) {\n            var actualClasses = getClassNamesFromAttributeValue(className);\n            if (typeof value === 'string') {\n              value = getClassNamesFromAttributeValue(value);\n            }\n            return topLevelExpect(\n              actualClasses.sort(),\n              'to equal',\n              value.sort()\n            );\n          }\n        });\n      }\n    );\n\n    expect.exportAssertion(\n      '<DOMTextNode> to [exhaustively] satisfy <DOMTextNode>',\n      function(expect, subject, value) {\n        return expect(subject.nodeValue, 'to equal', value.nodeValue);\n      }\n    );\n\n    // Avoid rendering a huge object diff when a text node is matched against a different node type:\n    expect.exportAssertion(\n      '<DOMTextNode> to [exhaustively] satisfy <object>',\n      function(expect, subject, value) {\n        expect.fail();\n      }\n    );\n\n    // Necessary because this case would otherwise be handled by the above catch-all for <object>:\n    expect.exportAssertion(\n      '<DOMTextNode> to [exhaustively] satisfy <regexp>',\n      function(expect, subject, value) {\n        return expect(subject.nodeValue, 'to satisfy', value);\n      }\n    );\n\n    expect.exportAssertion(\n      '<DOMTextNode> to [exhaustively] satisfy <any>',\n      function(expect, subject, value) {\n        return expect(subject.nodeValue, 'to satisfy', value);\n      }\n    );\n\n    function convertDOMNodeToSatisfySpec(node, isHtml) {\n      if (node.nodeType === 8 && node.nodeValue.trim() === 'ignore') {\n        // Ignore subtree\n        return {};\n      } else if (node.nodeType === 10) {\n        // HTMLDocType\n        return { name: node.nodeName };\n      } else if (node.nodeType === 1) {\n        // DOMElement\n        var result = {\n          name: isHtml ? node.nodeName.toLowerCase() : node.nodeName\n        };\n        if (node.attributes) {\n          result.attributes = {};\n          for (var i = 0; i < node.attributes.length; i += 1) {\n            result.attributes[node.attributes[i].name] =\n              isHtml && isBooleanAttribute(node.attributes[i].name)\n                ? true\n                : node.attributes[i].value || '';\n          }\n        }\n        result.children = Array.prototype.map.call(node.childNodes, function(\n          childNode\n        ) {\n          return convertDOMNodeToSatisfySpec(childNode, isHtml);\n        });\n        return result;\n      } else if (node.nodeType === 3) {\n        // DOMTextNode\n        return node.nodeValue;\n      } else {\n        throw new Error(\n          'to satisfy: Node type ' +\n            node.nodeType +\n            ' is not yet supported in the value'\n        );\n      }\n    }\n\n    expect.exportAssertion(\n      '<DOMNodeList> to [exhaustively] satisfy <string>',\n      function(expect, subject, value) {\n        var isHtml = subject.ownerDocument.contentType === 'text/html';\n        expect.argsOutput = function(output) {\n          return output.code(value, isHtml ? 'html' : 'xml');\n        };\n        return expect(\n          subject,\n          'to [exhaustively] satisfy',\n          (isHtml\n            ? parseHtml(value, true, expect.testDescription)\n            : parseXml(value, expect.testDescription)\n          ).childNodes\n        );\n      }\n    );\n\n    expect.exportAssertion(\n      '<DOMNodeList> to [exhaustively] satisfy <DOMNodeList>',\n      function(expect, subject, value) {\n        var isHtml = subject.ownerDocument.contentType === 'text/html';\n        var satisfySpecs = [];\n        for (var i = 0; i < value.length; i += 1) {\n          satisfySpecs.push(convertDOMNodeToSatisfySpec(value[i], isHtml));\n        }\n        return expect(subject, 'to [exhaustively] satisfy', satisfySpecs);\n      }\n    );\n\n    expect.exportAssertion(\n      '<DOMDocumentFragment> to [exhaustively] satisfy <string>',\n      function(expect, subject, value) {\n        var isHtml = isInsideHtmlDocument(subject);\n        expect.argsOutput = function(output) {\n          return output.code(value, isHtml ? 'html' : 'xml');\n        };\n        return expect(\n          subject,\n          'to [exhaustively] satisfy',\n          isHtml\n            ? parseHtml(value, true, expect.testDescription)\n            : parseXml(value, expect.testDescription)\n        );\n      }\n    );\n\n    expect.exportAssertion(\n      '<DOMDocumentFragment> to [exhaustively] satisfy <DOMDocumentFragment>',\n      function(expect, subject, value) {\n        var isHtml = subject.ownerDocument.contentType === 'text/html';\n        return expect(\n          subject,\n          'to [exhaustively] satisfy',\n          Array.prototype.map.call(value.childNodes, function(childNode) {\n            return convertDOMNodeToSatisfySpec(childNode, isHtml);\n          })\n        );\n      }\n    );\n\n    expect.exportAssertion(\n      '<DOMDocumentFragment> to [exhaustively] satisfy <object|array>',\n      function(expect, subject, value) {\n        return expect(subject.childNodes, 'to [exhaustively] satisfy', value);\n      }\n    );\n\n    expect.exportAssertion(\n      '<DOMElement> to [exhaustively] satisfy <string>',\n      function(expect, subject, value) {\n        var isHtml = isInsideHtmlDocument(subject);\n        var documentFragment = isHtml\n          ? parseHtml(value, true, this.testDescription)\n          : parseXml(value, this.testDescription);\n        if (documentFragment.childNodes.length !== 1) {\n          throw new Error(\n            'HTMLElement to satisfy string: Only a single node is supported'\n          );\n        }\n        expect.argsOutput = function(output) {\n          return output.code(value, isHtml ? 'html' : 'xml');\n        };\n        return expect(\n          subject,\n          'to [exhaustively] satisfy',\n          documentFragment.childNodes[0]\n        );\n      }\n    );\n\n    expect.exportAssertion(\n      '<DOMDocument> to [exhaustively] satisfy <string>',\n      function(expect, subject, value) {\n        var isHtml = isInsideHtmlDocument(subject);\n        var valueDocument = isHtml\n          ? parseHtml(value, false, this.testDescription)\n          : parseXml(value, this.testDescription);\n        return expect(\n          makeAttachedDOMNodeList(subject.childNodes),\n          'to [exhaustively] satisfy',\n          Array.prototype.map.call(valueDocument.childNodes, function(\n            childNode\n          ) {\n            return convertDOMNodeToSatisfySpec(childNode, isHtml);\n          })\n        );\n      }\n    );\n\n    expect.exportAssertion(\n      '<DOMDocument> to [exhaustively] satisfy <DOMDocument>',\n      function(expect, subject, value) {\n        var isHtml = isInsideHtmlDocument(subject);\n        return expect(\n          makeAttachedDOMNodeList(subject.childNodes),\n          'to [exhaustively] satisfy',\n          Array.prototype.map.call(value.childNodes, function(childNode) {\n            return convertDOMNodeToSatisfySpec(childNode, isHtml);\n          })\n        );\n      }\n    );\n\n    expect.exportAssertion(\n      '<DOMElement> to [exhaustively] satisfy <DOMElement>',\n      function(expect, subject, value) {\n        return expect(\n          subject,\n          'to [exhaustively] satisfy',\n          convertDOMNodeToSatisfySpec(value, isInsideHtmlDocument(subject))\n        );\n      }\n    );\n\n    expect.exportAssertion(\n      '<DOMElement> to [exhaustively] satisfy <DOMTextNode>',\n      function(expect, subject, value) {\n        expect.fail();\n      }\n    );\n\n    expect.exportAssertion(\n      '<DOMTextNode> to [exhaustively] satisfy <DOMElement>',\n      function(expect, subject, value) {\n        expect.fail();\n      }\n    );\n\n    expect.exportAssertion(\n      '<DOMElement> to [exhaustively] satisfy <object>',\n      function(expect, subject, value) {\n        var isHtml = isInsideHtmlDocument(subject);\n        var unsupportedOptions = Object.keys(value).filter(function(key) {\n          return (\n            key !== 'attributes' &&\n            key !== 'name' &&\n            key !== 'children' &&\n            key !== 'onlyAttributes' &&\n            key !== 'textContent'\n          );\n        });\n        if (unsupportedOptions.length > 0) {\n          throw new Error(\n            'Unsupported option' +\n              (unsupportedOptions.length === 1 ? '' : 's') +\n              ': ' +\n              unsupportedOptions.join(', ')\n          );\n        }\n\n        var promiseByKey = {\n          name: expect.promise(function() {\n            if (value && typeof value.name !== 'undefined') {\n              return topLevelExpect(\n                isHtml ? subject.nodeName.toLowerCase() : subject.nodeName,\n                'to satisfy',\n                value.name\n              );\n            }\n          }),\n          children: expect.promise(function() {\n            if (typeof value.children !== 'undefined') {\n              if (typeof value.textContent !== 'undefined') {\n                throw new Error(\n                  'The children and textContent properties are not supported together'\n                );\n              }\n              return topLevelExpect(\n                makeAttachedDOMNodeList(\n                  subject.childNodes,\n                  subject.ownerDocument.contentType\n                ),\n                'to satisfy',\n                value.children\n              );\n            } else if (typeof value.textContent !== 'undefined') {\n              return topLevelExpect(\n                subject.textContent,\n                'to satisfy',\n                value.textContent\n              );\n            }\n          }),\n          attributes: {}\n        };\n\n        var onlyAttributes =\n          (value && value.onlyAttributes) || expect.flags.exhaustively;\n        var attrs = getAttributes(subject);\n        var expectedAttributes = value && value.attributes;\n        var expectedAttributeNames = [];\n\n        if (typeof expectedAttributes !== 'undefined') {\n          if (typeof expectedAttributes === 'string') {\n            expectedAttributes = [expectedAttributes];\n          }\n          var expectedValueByAttributeName = {};\n          if (Array.isArray(expectedAttributes)) {\n            expectedAttributes.forEach(function(attributeName) {\n              expectedValueByAttributeName[attributeName] = true;\n            });\n          } else if (\n            expectedAttributes &&\n            typeof expectedAttributes === 'object'\n          ) {\n            expectedValueByAttributeName = expectedAttributes;\n          }\n          Object.keys(expectedValueByAttributeName).forEach(function(\n            attributeName\n          ) {\n            expectedAttributeNames.push(attributeName);\n          });\n\n          expectedAttributeNames.forEach(function(attributeName) {\n            var attributeValue = subject.getAttribute(attributeName);\n            var expectedAttributeValue =\n              expectedValueByAttributeName[attributeName];\n            promiseByKey.attributes[attributeName] = expect.promise(function() {\n              if (expectedAttributeValue === true) {\n                topLevelExpect(\n                  subject.hasAttribute(attributeName),\n                  'to be true'\n                );\n              } else if (typeof expectedAttributeValue === 'undefined') {\n                topLevelExpect(\n                  subject.hasAttribute(attributeName),\n                  'to be false'\n                );\n              } else if (\n                attributeName === 'class' &&\n                (typeof expectedAttributeValue === 'string' ||\n                  Array.isArray(expectedAttributeValue))\n              ) {\n                var actualClasses = getClassNamesFromAttributeValue(\n                  attributeValue\n                );\n                var expectedClasses = expectedAttributeValue;\n                if (typeof expectedClasses === 'string') {\n                  expectedClasses = getClassNamesFromAttributeValue(\n                    expectedAttributeValue\n                  );\n                }\n                if (onlyAttributes) {\n                  return topLevelExpect(\n                    actualClasses.sort(),\n                    'to equal',\n                    expectedClasses.sort()\n                  );\n                } else {\n                  return topLevelExpect.apply(\n                    topLevelExpect,\n                    [actualClasses, 'to contain'].concat(expectedClasses)\n                  );\n                }\n              } else if (attributeName === 'style') {\n                var expectedStyleObj;\n                if (typeof expectedValueByAttributeName.style === 'string') {\n                  expectedStyleObj = styleStringToObject(\n                    expectedValueByAttributeName.style\n                  );\n                } else {\n                  expectedStyleObj = expectedValueByAttributeName.style;\n                }\n\n                if (onlyAttributes) {\n                  return topLevelExpect(\n                    attrs.style,\n                    'to exhaustively satisfy',\n                    expectedStyleObj\n                  );\n                } else {\n                  return topLevelExpect(\n                    attrs.style,\n                    'to satisfy',\n                    expectedStyleObj\n                  );\n                }\n              } else {\n                return topLevelExpect(\n                  attributeValue,\n                  'to satisfy',\n                  expectedAttributeValue\n                );\n              }\n            });\n          });\n\n          promiseByKey.attributePresence = expect.promise(function() {\n            var attributeNamesExpectedToBeDefined = [];\n            expectedAttributeNames.forEach(function(attributeName) {\n              if (\n                typeof expectedValueByAttributeName[attributeName] ===\n                'undefined'\n              ) {\n                expect(attrs, 'not to have key', attributeName);\n              } else {\n                attributeNamesExpectedToBeDefined.push(attributeName);\n                expect(attrs, 'to have key', attributeName);\n              }\n            });\n            if (onlyAttributes) {\n              expect(\n                Object.keys(attrs).sort(),\n                'to equal',\n                attributeNamesExpectedToBeDefined.sort()\n              );\n            }\n          });\n        }\n\n        return expect.promise.all(promiseByKey).caught(function() {\n          return expect.promise.settle(promiseByKey).then(function() {\n            expect.fail({\n              diff: function(output, diff, inspect, equal) {\n                output.block(function() {\n                  var output = this;\n                  var seenError = false;\n                  output\n                    .prismPunctuation('<')\n                    .prismTag(\n                      isHtml ? subject.nodeName.toLowerCase() : subject.nodeName\n                    );\n                  if (promiseByKey.name.isRejected()) {\n                    seenError = true;\n                    var nameError = promiseByKey.name.reason();\n                    output.sp().annotationBlock(function() {\n                      this.error(\n                        (nameError && nameError.getLabel()) || 'should satisfy'\n                      )\n                        .sp()\n                        .append(inspect(value.name));\n                    });\n                  }\n                  var inspectedAttributes = [];\n                  Object.keys(attrs).forEach(function(attributeName) {\n                    var attributeOutput = output.clone();\n                    var promise = promiseByKey.attributes[attributeName];\n                    writeAttributeToMagicPen(\n                      attributeOutput,\n                      attributeName,\n                      attrs[attributeName],\n                      isHtml\n                    );\n                    if (\n                      (promise && promise.isFulfilled()) ||\n                      (!promise &&\n                        (!onlyAttributes ||\n                          expectedAttributeNames.indexOf(attributeName) !== -1))\n                    ) {\n                    } else {\n                      seenError = true;\n                      attributeOutput.sp().annotationBlock(function() {\n                        if (\n                          promise &&\n                          typeof expectedValueByAttributeName[attributeName] !==\n                            'undefined'\n                        ) {\n                          this.append(promise.reason().getErrorMessage(this));\n                        } else {\n                          // onlyAttributes === true\n                          this.error('should be removed');\n                        }\n                      });\n                    }\n                    inspectedAttributes.push(attributeOutput);\n                  });\n                  expectedAttributeNames.forEach(function(attributeName) {\n                    if (!subject.hasAttribute(attributeName)) {\n                      var promise = promiseByKey.attributes[attributeName];\n                      if (!promise || promise.isRejected()) {\n                        seenError = true;\n                        var err = promise && promise.reason();\n                        var attributeOutput = output\n                          .clone()\n                          .annotationBlock(function() {\n                            this.error('missing')\n                              .sp()\n                              .prismAttrName(attributeName, 'html');\n                            if (\n                              expectedValueByAttributeName[attributeName] !==\n                              true\n                            ) {\n                              this.sp()\n                                .error(\n                                  (err && err.getLabel()) || 'should satisfy'\n                                )\n                                .sp()\n                                .append(\n                                  inspect(\n                                    expectedValueByAttributeName[attributeName]\n                                  )\n                                );\n                            }\n                          });\n                        inspectedAttributes.push(attributeOutput);\n                      }\n                    }\n                  });\n                  if (inspectedAttributes.length > 0) {\n                    if (seenError) {\n                      output\n                        .nl()\n                        .indentLines()\n                        .indent()\n                        .block(function(output) {\n                          inspectedAttributes.forEach(function(item, i) {\n                            if (i > 0) {\n                              output.nl();\n                            }\n                            output.append(item);\n                          });\n                        })\n                        .outdentLines()\n                        .nl();\n                    } else {\n                      output.sp();\n                      inspectedAttributes.forEach(function(item, i) {\n                        if (i > 0) {\n                          output.sp();\n                        }\n                        output.append(item);\n                      });\n                    }\n                  } else if (seenError) {\n                    // The tag name mismatched\n                    output.nl();\n                  }\n\n                  output.prismPunctuation('>');\n                  var childrenError =\n                    promiseByKey.children.isRejected() &&\n                    promiseByKey.children.reason();\n                  if (childrenError) {\n                    var childrenDiff = childrenError.getDiff(output);\n                    if (childrenDiff && childrenDiff.inline) {\n                      this.nl()\n                        .indentLines()\n                        .i()\n                        .block(childrenDiff.diff)\n                        .nl()\n                        .outdentLines();\n                    } else {\n                      output\n                        .nl()\n                        .indentLines()\n                        .i()\n                        .block(function() {\n                          for (\n                            var i = 0;\n                            i < subject.childNodes.length;\n                            i += 1\n                          ) {\n                            this.append(inspect(subject.childNodes[i])).nl();\n                          }\n                        });\n                      output.sp().annotationBlock(function() {\n                        this.append(childrenError.getErrorMessage(this));\n                      });\n                      output.nl();\n                    }\n                  } else {\n                    for (var i = 0; i < subject.childNodes.length; i += 1) {\n                      this.append(inspect(subject.childNodes[i]));\n                    }\n                  }\n                  output.code(stringifyEndTag(subject), 'html');\n                });\n                output.inline = true;\n                return output;\n              }\n            });\n          });\n        });\n      }\n    );\n\n    expect.exportAssertion(\n      '<DOMElement> to [only] have (attribute|attributes) <string+>',\n      function(expect, subject, value) {\n        return expect(\n          subject,\n          'to [only] have attributes',\n          Array.prototype.slice.call(arguments, 2)\n        );\n      }\n    );\n\n    expect.exportAssertion(\n      '<DOMElement> not to have (attribute|attributes) <array>',\n      function(expect, subject, value) {\n        var attributes = getAttributes(subject);\n\n        value.forEach(function(name) {\n          delete attributes[name];\n        });\n\n        return expect(subject, 'to only have attributes', attributes);\n      }\n    );\n\n    expect.exportAssertion(\n      '<DOMElement> not to have (attribute|attributes) <string+>',\n      function(expect, subject, value) {\n        return expect(\n          subject,\n          'not to have attributes',\n          Array.prototype.slice.call(arguments, 2)\n        );\n      }\n    );\n\n    expect.exportAssertion(\n      '<DOMElement> to [only] have (attribute|attributes) <array|object>',\n      function(expect, subject, value) {\n        return expect(subject, 'to satisfy', {\n          attributes: value,\n          onlyAttributes: expect.flags.only\n        });\n      }\n    );\n\n    expect.exportAssertion('<DOMElement> to have no (child|children)', function(\n      expect,\n      subject\n    ) {\n      expect.errorMode = 'nested';\n      return expect(\n        Array.prototype.slice.call(subject.childNodes),\n        'to be an empty array'\n      );\n    });\n\n    expect.exportAssertion('<DOMElement> to have (child|children)', function(\n      expect,\n      subject\n    ) {\n      return expect(subject.childNodes, 'not to be empty');\n    });\n\n    expect.exportAssertion(\n      '<DOMElement> to have (child|children) <string>',\n      function(expect, subject, query) {\n        expect.errorMode = 'nested';\n        expect(subject.querySelectorAll(query), 'not to be empty');\n      }\n    );\n\n    expect.exportAssertion('<DOMElement> to have text <any>', function(\n      expect,\n      subject,\n      value\n    ) {\n      return expect(subject.textContent, 'to satisfy', value);\n    });\n\n    expect.exportAssertion(\n      '<DOMDocument|DOMElement|DOMDocumentFragment> [when] queried for [first] <string> <assertion?>',\n      function(expect, subject, query) {\n        var queryResult;\n\n        expect.argsOutput[0] = function(output) {\n          return output.green(query);\n        };\n\n        expect.errorMode = 'nested';\n\n        if (expect.flags.first) {\n          queryResult = subject.querySelector(query);\n          if (!queryResult) {\n            expect.fail(function(output) {\n              return output\n                .error('The selector')\n                .sp()\n                .jsString(query)\n                .sp()\n                .error('yielded no results');\n            });\n          }\n        } else {\n          queryResult = subject.querySelectorAll(query);\n          if (queryResult.length === 0) {\n            expect.fail(function(output) {\n              return output\n                .error('The selector')\n                .sp()\n                .jsString(query)\n                .sp()\n                .error('yielded no results');\n            });\n          }\n        }\n        return expect.shift(queryResult);\n      }\n    );\n\n    expect.exportAssertion(\n      '<DOMDocument|DOMElement|DOMDocumentFragment> to contain [no] elements matching <string>',\n      function(expect, subject, query) {\n        if (expect.flags.no) {\n          return expect(subject.querySelectorAll(query), 'to satisfy', []);\n        }\n\n        expect.subjectOutput = function(output) {\n          expect.inspect(subject, Infinity, output);\n        };\n        return expect(subject.querySelectorAll(query), 'not to satisfy', []);\n      }\n    );\n\n    expect.exportAssertion(\n      '<DOMDocument|DOMElement|DOMDocumentFragment> [not] to match <string>',\n      function(expect, subject, query) {\n        return expect(\n          matchesSelector(subject, query),\n          'to be',\n          !expect.flags.not\n        );\n      }\n    );\n\n    expect.exportAssertion(\n      '<string> [when] parsed as (html|HTML) [fragment] <assertion?>',\n      function(expect, subject) {\n        expect.errorMode = 'nested';\n        return expect.shift(\n          parseHtml(subject, expect.flags.fragment, expect.testDescription)\n        );\n      }\n    );\n\n    expect.exportAssertion(\n      '<string> [when] parsed as (xml|XML) <assertion?>',\n      function(expect, subject) {\n        expect.errorMode = 'nested';\n        return expect.shift(parseXml(subject, expect.testDescription));\n      }\n    );\n  }\n};\n","module.exports = function(elm, selector) {\n  var matchFuntion =\n    elm.matchesSelector ||\n    elm.mozMatchesSelector ||\n    elm.msMatchesSelector ||\n    elm.oMatchesSelector ||\n    elm.webkitMatchesSelector ||\n    function(selector) {\n      var node = this;\n      var nodes = (node.parentNode || node.document).querySelectorAll(selector);\n      var i = 0;\n\n      while (nodes[i] && nodes[i] !== node) {\n        i += 1;\n      }\n\n      return !!nodes[i];\n    };\n\n  return matchFuntion.call(elm, selector);\n};\n","var oldPrismGlobal = global.Prism;\nvar prism = global.Prism = require('prismjs');\nrequire('prismjs/components/prism-graphql.js');\nrequire('prismjs/components/prism-csp.js');\nglobal.Prism = oldPrismGlobal;\n\nvar defaultTheme = {\n    // Adapted from the default Prism theme:\n    prismComment: '#708090', // slategray\n    prismProlog: 'prismComment',\n    prismDoctype: 'prismComment',\n    prismCdata: 'prismComment',\n\n    prismPunctuation: '#999',\n\n    prismSymbol: '#905',\n    prismProperty: 'prismSymbol',\n    prismTag: 'prismSymbol',\n    prismBoolean: 'prismSymbol',\n    prismNumber: 'prismSymbol',\n    prismConstant: 'prismSymbol',\n    prismDeleted: 'prismSymbol',\n\n    prismString: '#690',\n    prismSelector: 'prismString',\n    prismAttrName: 'prismString',\n    prismChar: 'prismString',\n    prismBuiltin: 'prismString',\n    prismInserted: 'prismString',\n\n    prismOperator: '#a67f59',\n    prismVariable: 'prismOperator',\n    prismEntity: 'prismOperator',\n    prismUrl: 'prismOperator',\n    prismCssString: 'prismOperator',\n\n    prismKeyword: '#07a',\n    prismAtrule: 'prismKeyword',\n    prismAttrValue: 'prismKeyword',\n\n    prismFunction: '#DD4A68',\n\n    prismRegex: '#e90',\n    prismImportant: ['#e90', 'bold']\n};\n\nvar languageMapping = {\n    'text/html': 'markup',\n    'application/xml': 'markup',\n    'text/xml': 'markup',\n    'application/json': 'javascript',\n    'text/javascript': 'javascript',\n    'application/javascript': 'javascript',\n    'text/css': 'css',\n    html: 'markup',\n    xml: 'markup',\n    c: 'clike',\n    'c++': 'clike',\n    'cpp': 'clike',\n    'c#': 'clike',\n    java: 'clike',\n    'application/graphql': 'graphql'\n};\n\nfunction upperCamelCase(str) {\n    return str.replace(/(?:^|-)([a-z])/g, function ($0, ch) {\n        return ch.toUpperCase();\n    });\n}\n\nmodule.exports = {\n    name: 'magicpen-prism',\n    version: require('../package.json').version,\n    installInto: function (magicPen) {\n        magicPen.installTheme(defaultTheme);\n\n        magicPen.addStyle('code', function (sourceText, language) {\n            if (language in languageMapping) {\n                language = languageMapping[language];\n            } else if (/\\+xml\\b/.test(language)) {\n                language = 'markup';\n            }\n            if (!(language in prism.languages)) {\n                return this.text(sourceText);\n            }\n\n            var that = this;\n            var capitalizedLanguage = upperCamelCase(language);\n            var languageDefinition = prism.languages[language];\n\n            function printTokens(token, parentStyle) {\n                if (Array.isArray(token)) {\n                    token.forEach(function (subToken) {\n                        printTokens(subToken, parentStyle);\n                    });\n                } else if (typeof token === 'string') {\n                    var upperCamelCasedParentStyle = upperCamelCase(parentStyle);\n                    token = token.replace(/&lt;/g, '<');\n                    if (that['prism' + capitalizedLanguage + upperCamelCasedParentStyle]) {\n                        that['prism' + capitalizedLanguage + upperCamelCasedParentStyle](token);\n                    } else if (that['prism' + upperCamelCasedParentStyle]) {\n                        that['prism' + upperCamelCasedParentStyle](token);\n                    } else if (languageDefinition[parentStyle] && languageDefinition[parentStyle].alias) {\n                        printTokens(token, languageDefinition[parentStyle].alias);\n                    } else {\n                        that.text(token);\n                    }\n                } else {\n                    printTokens(token.content, token.type);\n                }\n            }\n            printTokens(prism.tokenize(sourceText, prism.languages[language]), 'text');\n        }, true);\n    }\n};\n","module.exports={\n  \"_from\": \"magicpen-prism@^2.3.0\",\n  \"_id\": \"magicpen-prism@2.4.0\",\n  \"_inBundle\": false,\n  \"_integrity\": \"sha512-OEFZ+xksJtYgwnU5jJqDXhjvgnSFfMsSgXpJ2WWPaBJUXNKuQB0FBAiQxjRKsV5gntpg/tazH8L3apJx5eMdJg==\",\n  \"_location\": \"/magicpen-prism\",\n  \"_phantomChildren\": {},\n  \"_requested\": {\n    \"type\": \"range\",\n    \"registry\": true,\n    \"raw\": \"magicpen-prism@^2.3.0\",\n    \"name\": \"magicpen-prism\",\n    \"escapedName\": \"magicpen-prism\",\n    \"rawSpec\": \"^2.3.0\",\n    \"saveSpec\": null,\n    \"fetchSpec\": \"^2.3.0\"\n  },\n  \"_requiredBy\": [\n    \"/\"\n  ],\n  \"_resolved\": \"https://registry.npmjs.org/magicpen-prism/-/magicpen-prism-2.4.0.tgz\",\n  \"_shasum\": \"aa79ca9b656f35069ad0aea8b102f1ac8642cbb0\",\n  \"_spec\": \"magicpen-prism@^2.3.0\",\n  \"_where\": \"/Users/ssimonsen/Code/unexpected-dom\",\n  \"author\": {\n    \"name\": \"Andreas Lind\",\n    \"email\": \"andreas@one.com\"\n  },\n  \"bugs\": {\n    \"url\": \"https://github.com/unexpectedjs/magicpen-prism/issues\"\n  },\n  \"bundleDependencies\": false,\n  \"dependencies\": {\n    \"prismjs\": \"1.11.0\"\n  },\n  \"deprecated\": false,\n  \"description\": \"Add syntax highlighting support to magicpen via prism.js\",\n  \"devDependencies\": {\n    \"browserify\": \"13.0.0\",\n    \"bundle-collapser\": \"1.2.1\",\n    \"eslint\": \"2.13.1\",\n    \"eslint-config-onelint\": \"1.2.0\",\n    \"magicpen\": \"5.9.0\",\n    \"mocha\": \"2.4.5\",\n    \"unexpected\": \"10.10.5\"\n  },\n  \"files\": [\n    \"lib\",\n    \"magicPenPrism.min.js\"\n  ],\n  \"homepage\": \"https://github.com/unexpectedjs/magicpen-prism#readme\",\n  \"main\": \"lib/magicPenPrism.js\",\n  \"name\": \"magicpen-prism\",\n  \"repository\": {\n    \"type\": \"git\",\n    \"url\": \"git+https://github.com/unexpectedjs/magicpen-prism.git\"\n  },\n  \"scripts\": {\n    \"lint\": \"eslint .\",\n    \"prepublish\": \"browserify -p bundle-collapser/plugin -e lib/magicPenPrism -s magicPenPrism > magicPenPrism.min.js\",\n    \"test\": \"mocha\",\n    \"travis\": \"npm run lint && npm test\"\n  },\n  \"version\": \"2.4.0\"\n}\n","/**\n * Original by Scott Helme.\n *\n * Reference: https://scotthelme.co.uk/csp-cheat-sheet/\n *\n * Supports the following:\n *  - CSP Level 1\n *  - CSP Level 2\n *  - CSP Level 3\n */\n\nPrism.languages.csp = {\n\t'directive':  {\n             pattern: /\\b(?:(?:base-uri|form-action|frame-ancestors|plugin-types|referrer|reflected-xss|report-to|report-uri|require-sri-for|sandbox) |(?:block-all-mixed-content|disown-opener|upgrade-insecure-requests)(?: |;)|(?:child|connect|default|font|frame|img|manifest|media|object|script|style|worker)-src )/i,\n             alias: 'keyword'\n        },\n\t'safe': {\n            pattern: /'(?:self|none|strict-dynamic|(?:nonce-|sha(?:256|384|512)-)[a-zA-Z0-9+=/]+)'/,\n            alias: 'selector'\n        },\n\t'unsafe': {\n            pattern: /(?:'unsafe-inline'|'unsafe-eval'|'unsafe-hashed-attributes'|\\*)/,\n            alias: 'function'\n        }\n};","Prism.languages.graphql = {\n\t'comment': /#.*/,\n\t'string': {\n\t\tpattern: /\"(?:\\\\.|[^\\\\\"\\r\\n])*\"/,\n\t\tgreedy: true\n\t},\n\t'number': /(?:\\B-|\\b)\\d+(?:\\.\\d+)?(?:[eE][+-]?\\d+)?\\b/,\n\t'boolean': /\\b(?:true|false)\\b/,\n\t'variable': /\\$[a-z_]\\w*/i,\n\t'directive': {\n\t\tpattern: /@[a-z_]\\w*/i,\n\t\talias: 'function'\n\t},\n\t'attr-name': /[a-z_]\\w*(?=\\s*:)/i,\n\t'keyword': [\n\t\t{\n\t\t\tpattern: /(fragment\\s+(?!on)[a-z_]\\w*\\s+|\\.{3}\\s*)on\\b/,\n\t\t\tlookbehind: true\n\t\t},\n\t\t/\\b(?:query|fragment|mutation)\\b/\n\t],\n\t'operator': /!|=|\\.{3}/,\n\t'punctuation': /[!(){}\\[\\]:=,]/\n};","\n/* **********************************************\n     Begin prism-core.js\n********************************************** */\n\nvar _self = (typeof window !== 'undefined')\n\t? window   // if in browser\n\t: (\n\t\t(typeof WorkerGlobalScope !== 'undefined' && self instanceof WorkerGlobalScope)\n\t\t? self // if in worker\n\t\t: {}   // if in node js\n\t);\n\n/**\n * Prism: Lightweight, robust, elegant syntax highlighting\n * MIT license http://www.opensource.org/licenses/mit-license.php/\n * @author Lea Verou http://lea.verou.me\n */\n\nvar Prism = (function(){\n\n// Private helper vars\nvar lang = /\\blang(?:uage)?-(\\w+)\\b/i;\nvar uniqueId = 0;\n\nvar _ = _self.Prism = {\n\tmanual: _self.Prism && _self.Prism.manual,\n\tdisableWorkerMessageHandler: _self.Prism && _self.Prism.disableWorkerMessageHandler,\n\tutil: {\n\t\tencode: function (tokens) {\n\t\t\tif (tokens instanceof Token) {\n\t\t\t\treturn new Token(tokens.type, _.util.encode(tokens.content), tokens.alias);\n\t\t\t} else if (_.util.type(tokens) === 'Array') {\n\t\t\t\treturn tokens.map(_.util.encode);\n\t\t\t} else {\n\t\t\t\treturn tokens.replace(/&/g, '&amp;').replace(/</g, '&lt;').replace(/\\u00a0/g, ' ');\n\t\t\t}\n\t\t},\n\n\t\ttype: function (o) {\n\t\t\treturn Object.prototype.toString.call(o).match(/\\[object (\\w+)\\]/)[1];\n\t\t},\n\n\t\tobjId: function (obj) {\n\t\t\tif (!obj['__id']) {\n\t\t\t\tObject.defineProperty(obj, '__id', { value: ++uniqueId });\n\t\t\t}\n\t\t\treturn obj['__id'];\n\t\t},\n\n\t\t// Deep clone a language definition (e.g. to extend it)\n\t\tclone: function (o) {\n\t\t\tvar type = _.util.type(o);\n\n\t\t\tswitch (type) {\n\t\t\t\tcase 'Object':\n\t\t\t\t\tvar clone = {};\n\n\t\t\t\t\tfor (var key in o) {\n\t\t\t\t\t\tif (o.hasOwnProperty(key)) {\n\t\t\t\t\t\t\tclone[key] = _.util.clone(o[key]);\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\n\t\t\t\t\treturn clone;\n\n\t\t\t\tcase 'Array':\n\t\t\t\t\treturn o.map(function(v) { return _.util.clone(v); });\n\t\t\t}\n\n\t\t\treturn o;\n\t\t}\n\t},\n\n\tlanguages: {\n\t\textend: function (id, redef) {\n\t\t\tvar lang = _.util.clone(_.languages[id]);\n\n\t\t\tfor (var key in redef) {\n\t\t\t\tlang[key] = redef[key];\n\t\t\t}\n\n\t\t\treturn lang;\n\t\t},\n\n\t\t/**\n\t\t * Insert a token before another token in a language literal\n\t\t * As this needs to recreate the object (we cannot actually insert before keys in object literals),\n\t\t * we cannot just provide an object, we need anobject and a key.\n\t\t * @param inside The key (or language id) of the parent\n\t\t * @param before The key to insert before. If not provided, the function appends instead.\n\t\t * @param insert Object with the key/value pairs to insert\n\t\t * @param root The object that contains `inside`. If equal to Prism.languages, it can be omitted.\n\t\t */\n\t\tinsertBefore: function (inside, before, insert, root) {\n\t\t\troot = root || _.languages;\n\t\t\tvar grammar = root[inside];\n\n\t\t\tif (arguments.length == 2) {\n\t\t\t\tinsert = arguments[1];\n\n\t\t\t\tfor (var newToken in insert) {\n\t\t\t\t\tif (insert.hasOwnProperty(newToken)) {\n\t\t\t\t\t\tgrammar[newToken] = insert[newToken];\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\treturn grammar;\n\t\t\t}\n\n\t\t\tvar ret = {};\n\n\t\t\tfor (var token in grammar) {\n\n\t\t\t\tif (grammar.hasOwnProperty(token)) {\n\n\t\t\t\t\tif (token == before) {\n\n\t\t\t\t\t\tfor (var newToken in insert) {\n\n\t\t\t\t\t\t\tif (insert.hasOwnProperty(newToken)) {\n\t\t\t\t\t\t\t\tret[newToken] = insert[newToken];\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\n\t\t\t\t\tret[token] = grammar[token];\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t// Update references in other language definitions\n\t\t\t_.languages.DFS(_.languages, function(key, value) {\n\t\t\t\tif (value === root[inside] && key != inside) {\n\t\t\t\t\tthis[key] = ret;\n\t\t\t\t}\n\t\t\t});\n\n\t\t\treturn root[inside] = ret;\n\t\t},\n\n\t\t// Traverse a language definition with Depth First Search\n\t\tDFS: function(o, callback, type, visited) {\n\t\t\tvisited = visited || {};\n\t\t\tfor (var i in o) {\n\t\t\t\tif (o.hasOwnProperty(i)) {\n\t\t\t\t\tcallback.call(o, i, o[i], type || i);\n\n\t\t\t\t\tif (_.util.type(o[i]) === 'Object' && !visited[_.util.objId(o[i])]) {\n\t\t\t\t\t\tvisited[_.util.objId(o[i])] = true;\n\t\t\t\t\t\t_.languages.DFS(o[i], callback, null, visited);\n\t\t\t\t\t}\n\t\t\t\t\telse if (_.util.type(o[i]) === 'Array' && !visited[_.util.objId(o[i])]) {\n\t\t\t\t\t\tvisited[_.util.objId(o[i])] = true;\n\t\t\t\t\t\t_.languages.DFS(o[i], callback, i, visited);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t},\n\tplugins: {},\n\n\thighlightAll: function(async, callback) {\n\t\t_.highlightAllUnder(document, async, callback);\n\t},\n\n\thighlightAllUnder: function(container, async, callback) {\n\t\tvar env = {\n\t\t\tcallback: callback,\n\t\t\tselector: 'code[class*=\"language-\"], [class*=\"language-\"] code, code[class*=\"lang-\"], [class*=\"lang-\"] code'\n\t\t};\n\n\t\t_.hooks.run(\"before-highlightall\", env);\n\n\t\tvar elements = env.elements || container.querySelectorAll(env.selector);\n\n\t\tfor (var i=0, element; element = elements[i++];) {\n\t\t\t_.highlightElement(element, async === true, env.callback);\n\t\t}\n\t},\n\n\thighlightElement: function(element, async, callback) {\n\t\t// Find language\n\t\tvar language, grammar, parent = element;\n\n\t\twhile (parent && !lang.test(parent.className)) {\n\t\t\tparent = parent.parentNode;\n\t\t}\n\n\t\tif (parent) {\n\t\t\tlanguage = (parent.className.match(lang) || [,''])[1].toLowerCase();\n\t\t\tgrammar = _.languages[language];\n\t\t}\n\n\t\t// Set language on the element, if not present\n\t\telement.className = element.className.replace(lang, '').replace(/\\s+/g, ' ') + ' language-' + language;\n\n\t\tif (element.parentNode) {\n\t\t\t// Set language on the parent, for styling\n\t\t\tparent = element.parentNode;\n\n\t\t\tif (/pre/i.test(parent.nodeName)) {\n\t\t\t\tparent.className = parent.className.replace(lang, '').replace(/\\s+/g, ' ') + ' language-' + language;\n\t\t\t}\n\t\t}\n\n\t\tvar code = element.textContent;\n\n\t\tvar env = {\n\t\t\telement: element,\n\t\t\tlanguage: language,\n\t\t\tgrammar: grammar,\n\t\t\tcode: code\n\t\t};\n\n\t\t_.hooks.run('before-sanity-check', env);\n\n\t\tif (!env.code || !env.grammar) {\n\t\t\tif (env.code) {\n\t\t\t\t_.hooks.run('before-highlight', env);\n\t\t\t\tenv.element.textContent = env.code;\n\t\t\t\t_.hooks.run('after-highlight', env);\n\t\t\t}\n\t\t\t_.hooks.run('complete', env);\n\t\t\treturn;\n\t\t}\n\n\t\t_.hooks.run('before-highlight', env);\n\n\t\tif (async && _self.Worker) {\n\t\t\tvar worker = new Worker(_.filename);\n\n\t\t\tworker.onmessage = function(evt) {\n\t\t\t\tenv.highlightedCode = evt.data;\n\n\t\t\t\t_.hooks.run('before-insert', env);\n\n\t\t\t\tenv.element.innerHTML = env.highlightedCode;\n\n\t\t\t\tcallback && callback.call(env.element);\n\t\t\t\t_.hooks.run('after-highlight', env);\n\t\t\t\t_.hooks.run('complete', env);\n\t\t\t};\n\n\t\t\tworker.postMessage(JSON.stringify({\n\t\t\t\tlanguage: env.language,\n\t\t\t\tcode: env.code,\n\t\t\t\timmediateClose: true\n\t\t\t}));\n\t\t}\n\t\telse {\n\t\t\tenv.highlightedCode = _.highlight(env.code, env.grammar, env.language);\n\n\t\t\t_.hooks.run('before-insert', env);\n\n\t\t\tenv.element.innerHTML = env.highlightedCode;\n\n\t\t\tcallback && callback.call(element);\n\n\t\t\t_.hooks.run('after-highlight', env);\n\t\t\t_.hooks.run('complete', env);\n\t\t}\n\t},\n\n\thighlight: function (text, grammar, language) {\n\t\tvar tokens = _.tokenize(text, grammar);\n\t\treturn Token.stringify(_.util.encode(tokens), language);\n\t},\n\n\tmatchGrammar: function (text, strarr, grammar, index, startPos, oneshot, target) {\n\t\tvar Token = _.Token;\n\n\t\tfor (var token in grammar) {\n\t\t\tif(!grammar.hasOwnProperty(token) || !grammar[token]) {\n\t\t\t\tcontinue;\n\t\t\t}\n\n\t\t\tif (token == target) {\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\tvar patterns = grammar[token];\n\t\t\tpatterns = (_.util.type(patterns) === \"Array\") ? patterns : [patterns];\n\n\t\t\tfor (var j = 0; j < patterns.length; ++j) {\n\t\t\t\tvar pattern = patterns[j],\n\t\t\t\t\tinside = pattern.inside,\n\t\t\t\t\tlookbehind = !!pattern.lookbehind,\n\t\t\t\t\tgreedy = !!pattern.greedy,\n\t\t\t\t\tlookbehindLength = 0,\n\t\t\t\t\talias = pattern.alias;\n\n\t\t\t\tif (greedy && !pattern.pattern.global) {\n\t\t\t\t\t// Without the global flag, lastIndex won't work\n\t\t\t\t\tvar flags = pattern.pattern.toString().match(/[imuy]*$/)[0];\n\t\t\t\t\tpattern.pattern = RegExp(pattern.pattern.source, flags + \"g\");\n\t\t\t\t}\n\n\t\t\t\tpattern = pattern.pattern || pattern;\n\n\t\t\t\t// Don’t cache length as it changes during the loop\n\t\t\t\tfor (var i = index, pos = startPos; i < strarr.length; pos += strarr[i].length, ++i) {\n\n\t\t\t\t\tvar str = strarr[i];\n\n\t\t\t\t\tif (strarr.length > text.length) {\n\t\t\t\t\t\t// Something went terribly wrong, ABORT, ABORT!\n\t\t\t\t\t\treturn;\n\t\t\t\t\t}\n\n\t\t\t\t\tif (str instanceof Token) {\n\t\t\t\t\t\tcontinue;\n\t\t\t\t\t}\n\n\t\t\t\t\tpattern.lastIndex = 0;\n\n\t\t\t\t\tvar match = pattern.exec(str),\n\t\t\t\t\t    delNum = 1;\n\n\t\t\t\t\t// Greedy patterns can override/remove up to two previously matched tokens\n\t\t\t\t\tif (!match && greedy && i != strarr.length - 1) {\n\t\t\t\t\t\tpattern.lastIndex = pos;\n\t\t\t\t\t\tmatch = pattern.exec(text);\n\t\t\t\t\t\tif (!match) {\n\t\t\t\t\t\t\tbreak;\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\tvar from = match.index + (lookbehind ? match[1].length : 0),\n\t\t\t\t\t\t    to = match.index + match[0].length,\n\t\t\t\t\t\t    k = i,\n\t\t\t\t\t\t    p = pos;\n\n\t\t\t\t\t\tfor (var len = strarr.length; k < len && (p < to || (!strarr[k].type && !strarr[k - 1].greedy)); ++k) {\n\t\t\t\t\t\t\tp += strarr[k].length;\n\t\t\t\t\t\t\t// Move the index i to the element in strarr that is closest to from\n\t\t\t\t\t\t\tif (from >= p) {\n\t\t\t\t\t\t\t\t++i;\n\t\t\t\t\t\t\t\tpos = p;\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\t/*\n\t\t\t\t\t\t * If strarr[i] is a Token, then the match starts inside another Token, which is invalid\n\t\t\t\t\t\t * If strarr[k - 1] is greedy we are in conflict with another greedy pattern\n\t\t\t\t\t\t */\n\t\t\t\t\t\tif (strarr[i] instanceof Token || strarr[k - 1].greedy) {\n\t\t\t\t\t\t\tcontinue;\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\t// Number of tokens to delete and replace with the new match\n\t\t\t\t\t\tdelNum = k - i;\n\t\t\t\t\t\tstr = text.slice(pos, p);\n\t\t\t\t\t\tmatch.index -= pos;\n\t\t\t\t\t}\n\n\t\t\t\t\tif (!match) {\n\t\t\t\t\t\tif (oneshot) {\n\t\t\t\t\t\t\tbreak;\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\tcontinue;\n\t\t\t\t\t}\n\n\t\t\t\t\tif(lookbehind) {\n\t\t\t\t\t\tlookbehindLength = match[1].length;\n\t\t\t\t\t}\n\n\t\t\t\t\tvar from = match.index + lookbehindLength,\n\t\t\t\t\t    match = match[0].slice(lookbehindLength),\n\t\t\t\t\t    to = from + match.length,\n\t\t\t\t\t    before = str.slice(0, from),\n\t\t\t\t\t    after = str.slice(to);\n\n\t\t\t\t\tvar args = [i, delNum];\n\n\t\t\t\t\tif (before) {\n\t\t\t\t\t\t++i;\n\t\t\t\t\t\tpos += before.length;\n\t\t\t\t\t\targs.push(before);\n\t\t\t\t\t}\n\n\t\t\t\t\tvar wrapped = new Token(token, inside? _.tokenize(match, inside) : match, alias, match, greedy);\n\n\t\t\t\t\targs.push(wrapped);\n\n\t\t\t\t\tif (after) {\n\t\t\t\t\t\targs.push(after);\n\t\t\t\t\t}\n\n\t\t\t\t\tArray.prototype.splice.apply(strarr, args);\n\n\t\t\t\t\tif (delNum != 1)\n\t\t\t\t\t\t_.matchGrammar(text, strarr, grammar, i, pos, true, token);\n\n\t\t\t\t\tif (oneshot)\n\t\t\t\t\t\tbreak;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t},\n\n\ttokenize: function(text, grammar, language) {\n\t\tvar strarr = [text];\n\n\t\tvar rest = grammar.rest;\n\n\t\tif (rest) {\n\t\t\tfor (var token in rest) {\n\t\t\t\tgrammar[token] = rest[token];\n\t\t\t}\n\n\t\t\tdelete grammar.rest;\n\t\t}\n\n\t\t_.matchGrammar(text, strarr, grammar, 0, 0, false);\n\n\t\treturn strarr;\n\t},\n\n\thooks: {\n\t\tall: {},\n\n\t\tadd: function (name, callback) {\n\t\t\tvar hooks = _.hooks.all;\n\n\t\t\thooks[name] = hooks[name] || [];\n\n\t\t\thooks[name].push(callback);\n\t\t},\n\n\t\trun: function (name, env) {\n\t\t\tvar callbacks = _.hooks.all[name];\n\n\t\t\tif (!callbacks || !callbacks.length) {\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\tfor (var i=0, callback; callback = callbacks[i++];) {\n\t\t\t\tcallback(env);\n\t\t\t}\n\t\t}\n\t}\n};\n\nvar Token = _.Token = function(type, content, alias, matchedStr, greedy) {\n\tthis.type = type;\n\tthis.content = content;\n\tthis.alias = alias;\n\t// Copy of the full string this token was created from\n\tthis.length = (matchedStr || \"\").length|0;\n\tthis.greedy = !!greedy;\n};\n\nToken.stringify = function(o, language, parent) {\n\tif (typeof o == 'string') {\n\t\treturn o;\n\t}\n\n\tif (_.util.type(o) === 'Array') {\n\t\treturn o.map(function(element) {\n\t\t\treturn Token.stringify(element, language, o);\n\t\t}).join('');\n\t}\n\n\tvar env = {\n\t\ttype: o.type,\n\t\tcontent: Token.stringify(o.content, language, parent),\n\t\ttag: 'span',\n\t\tclasses: ['token', o.type],\n\t\tattributes: {},\n\t\tlanguage: language,\n\t\tparent: parent\n\t};\n\n\tif (o.alias) {\n\t\tvar aliases = _.util.type(o.alias) === 'Array' ? o.alias : [o.alias];\n\t\tArray.prototype.push.apply(env.classes, aliases);\n\t}\n\n\t_.hooks.run('wrap', env);\n\n\tvar attributes = Object.keys(env.attributes).map(function(name) {\n\t\treturn name + '=\"' + (env.attributes[name] || '').replace(/\"/g, '&quot;') + '\"';\n\t}).join(' ');\n\n\treturn '<' + env.tag + ' class=\"' + env.classes.join(' ') + '\"' + (attributes ? ' ' + attributes : '') + '>' + env.content + '</' + env.tag + '>';\n\n};\n\nif (!_self.document) {\n\tif (!_self.addEventListener) {\n\t\t// in Node.js\n\t\treturn _self.Prism;\n\t}\n\n\tif (!_.disableWorkerMessageHandler) {\n\t\t// In worker\n\t\t_self.addEventListener('message', function (evt) {\n\t\t\tvar message = JSON.parse(evt.data),\n\t\t\t\tlang = message.language,\n\t\t\t\tcode = message.code,\n\t\t\t\timmediateClose = message.immediateClose;\n\n\t\t\t_self.postMessage(_.highlight(code, _.languages[lang], lang));\n\t\t\tif (immediateClose) {\n\t\t\t\t_self.close();\n\t\t\t}\n\t\t}, false);\n\t}\n\n\treturn _self.Prism;\n}\n\n//Get current script and highlight\nvar script = document.currentScript || [].slice.call(document.getElementsByTagName(\"script\")).pop();\n\nif (script) {\n\t_.filename = script.src;\n\n\tif (!_.manual && !script.hasAttribute('data-manual')) {\n\t\tif(document.readyState !== \"loading\") {\n\t\t\tif (window.requestAnimationFrame) {\n\t\t\t\twindow.requestAnimationFrame(_.highlightAll);\n\t\t\t} else {\n\t\t\t\twindow.setTimeout(_.highlightAll, 16);\n\t\t\t}\n\t\t}\n\t\telse {\n\t\t\tdocument.addEventListener('DOMContentLoaded', _.highlightAll);\n\t\t}\n\t}\n}\n\nreturn _self.Prism;\n\n})();\n\nif (typeof module !== 'undefined' && module.exports) {\n\tmodule.exports = Prism;\n}\n\n// hack for components to work correctly in node.js\nif (typeof global !== 'undefined') {\n\tglobal.Prism = Prism;\n}\n\n\n/* **********************************************\n     Begin prism-markup.js\n********************************************** */\n\nPrism.languages.markup = {\n\t'comment': /<!--[\\s\\S]*?-->/,\n\t'prolog': /<\\?[\\s\\S]+?\\?>/,\n\t'doctype': /<!DOCTYPE[\\s\\S]+?>/i,\n\t'cdata': /<!\\[CDATA\\[[\\s\\S]*?]]>/i,\n\t'tag': {\n\t\tpattern: /<\\/?(?!\\d)[^\\s>\\/=$<]+(?:\\s+[^\\s>\\/=]+(?:=(?:(\"|')(?:\\\\[\\s\\S]|(?!\\1)[^\\\\])*\\1|[^\\s'\">=]+))?)*\\s*\\/?>/i,\n\t\tinside: {\n\t\t\t'tag': {\n\t\t\t\tpattern: /^<\\/?[^\\s>\\/]+/i,\n\t\t\t\tinside: {\n\t\t\t\t\t'punctuation': /^<\\/?/,\n\t\t\t\t\t'namespace': /^[^\\s>\\/:]+:/\n\t\t\t\t}\n\t\t\t},\n\t\t\t'attr-value': {\n\t\t\t\tpattern: /=(?:(\"|')(?:\\\\[\\s\\S]|(?!\\1)[^\\\\])*\\1|[^\\s'\">=]+)/i,\n\t\t\t\tinside: {\n\t\t\t\t\t'punctuation': [\n\t\t\t\t\t\t/^=/,\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tpattern: /(^|[^\\\\])[\"']/,\n\t\t\t\t\t\t\tlookbehind: true\n\t\t\t\t\t\t}\n\t\t\t\t\t]\n\t\t\t\t}\n\t\t\t},\n\t\t\t'punctuation': /\\/?>/,\n\t\t\t'attr-name': {\n\t\t\t\tpattern: /[^\\s>\\/]+/,\n\t\t\t\tinside: {\n\t\t\t\t\t'namespace': /^[^\\s>\\/:]+:/\n\t\t\t\t}\n\t\t\t}\n\n\t\t}\n\t},\n\t'entity': /&#?[\\da-z]{1,8};/i\n};\n\nPrism.languages.markup['tag'].inside['attr-value'].inside['entity'] =\n\tPrism.languages.markup['entity'];\n\n// Plugin to make entity title show the real entity, idea by Roman Komarov\nPrism.hooks.add('wrap', function(env) {\n\n\tif (env.type === 'entity') {\n\t\tenv.attributes['title'] = env.content.replace(/&amp;/, '&');\n\t}\n});\n\nPrism.languages.xml = Prism.languages.markup;\nPrism.languages.html = Prism.languages.markup;\nPrism.languages.mathml = Prism.languages.markup;\nPrism.languages.svg = Prism.languages.markup;\n\n\n/* **********************************************\n     Begin prism-css.js\n********************************************** */\n\nPrism.languages.css = {\n\t'comment': /\\/\\*[\\s\\S]*?\\*\\//,\n\t'atrule': {\n\t\tpattern: /@[\\w-]+?.*?(?:;|(?=\\s*\\{))/i,\n\t\tinside: {\n\t\t\t'rule': /@[\\w-]+/\n\t\t\t// See rest below\n\t\t}\n\t},\n\t'url': /url\\((?:([\"'])(?:\\\\(?:\\r\\n|[\\s\\S])|(?!\\1)[^\\\\\\r\\n])*\\1|.*?)\\)/i,\n\t'selector': /[^{}\\s][^{};]*?(?=\\s*\\{)/,\n\t'string': {\n\t\tpattern: /(\"|')(?:\\\\(?:\\r\\n|[\\s\\S])|(?!\\1)[^\\\\\\r\\n])*\\1/,\n\t\tgreedy: true\n\t},\n\t'property': /[-_a-z\\xA0-\\uFFFF][-\\w\\xA0-\\uFFFF]*(?=\\s*:)/i,\n\t'important': /\\B!important\\b/i,\n\t'function': /[-a-z0-9]+(?=\\()/i,\n\t'punctuation': /[(){};:]/\n};\n\nPrism.languages.css['atrule'].inside.rest = Prism.util.clone(Prism.languages.css);\n\nif (Prism.languages.markup) {\n\tPrism.languages.insertBefore('markup', 'tag', {\n\t\t'style': {\n\t\t\tpattern: /(<style[\\s\\S]*?>)[\\s\\S]*?(?=<\\/style>)/i,\n\t\t\tlookbehind: true,\n\t\t\tinside: Prism.languages.css,\n\t\t\talias: 'language-css',\n\t\t\tgreedy: true\n\t\t}\n\t});\n\n\tPrism.languages.insertBefore('inside', 'attr-value', {\n\t\t'style-attr': {\n\t\t\tpattern: /\\s*style=(\"|')(?:\\\\[\\s\\S]|(?!\\1)[^\\\\])*\\1/i,\n\t\t\tinside: {\n\t\t\t\t'attr-name': {\n\t\t\t\t\tpattern: /^\\s*style/i,\n\t\t\t\t\tinside: Prism.languages.markup.tag.inside\n\t\t\t\t},\n\t\t\t\t'punctuation': /^\\s*=\\s*['\"]|['\"]\\s*$/,\n\t\t\t\t'attr-value': {\n\t\t\t\t\tpattern: /.+/i,\n\t\t\t\t\tinside: Prism.languages.css\n\t\t\t\t}\n\t\t\t},\n\t\t\talias: 'language-css'\n\t\t}\n\t}, Prism.languages.markup.tag);\n}\n\n/* **********************************************\n     Begin prism-clike.js\n********************************************** */\n\nPrism.languages.clike = {\n\t'comment': [\n\t\t{\n\t\t\tpattern: /(^|[^\\\\])\\/\\*[\\s\\S]*?(?:\\*\\/|$)/,\n\t\t\tlookbehind: true\n\t\t},\n\t\t{\n\t\t\tpattern: /(^|[^\\\\:])\\/\\/.*/,\n\t\t\tlookbehind: true\n\t\t}\n\t],\n\t'string': {\n\t\tpattern: /([\"'])(?:\\\\(?:\\r\\n|[\\s\\S])|(?!\\1)[^\\\\\\r\\n])*\\1/,\n\t\tgreedy: true\n\t},\n\t'class-name': {\n\t\tpattern: /((?:\\b(?:class|interface|extends|implements|trait|instanceof|new)\\s+)|(?:catch\\s+\\())[\\w.\\\\]+/i,\n\t\tlookbehind: true,\n\t\tinside: {\n\t\t\tpunctuation: /[.\\\\]/\n\t\t}\n\t},\n\t'keyword': /\\b(?:if|else|while|do|for|return|in|instanceof|function|new|try|throw|catch|finally|null|break|continue)\\b/,\n\t'boolean': /\\b(?:true|false)\\b/,\n\t'function': /[a-z0-9_]+(?=\\()/i,\n\t'number': /\\b-?(?:0x[\\da-f]+|\\d*\\.?\\d+(?:e[+-]?\\d+)?)\\b/i,\n\t'operator': /--?|\\+\\+?|!=?=?|<=?|>=?|==?=?|&&?|\\|\\|?|\\?|\\*|\\/|~|\\^|%/,\n\t'punctuation': /[{}[\\];(),.:]/\n};\n\n\n/* **********************************************\n     Begin prism-javascript.js\n********************************************** */\n\nPrism.languages.javascript = Prism.languages.extend('clike', {\n\t'keyword': /\\b(?:as|async|await|break|case|catch|class|const|continue|debugger|default|delete|do|else|enum|export|extends|finally|for|from|function|get|if|implements|import|in|instanceof|interface|let|new|null|of|package|private|protected|public|return|set|static|super|switch|this|throw|try|typeof|var|void|while|with|yield)\\b/,\n\t'number': /\\b-?(?:0[xX][\\dA-Fa-f]+|0[bB][01]+|0[oO][0-7]+|\\d*\\.?\\d+(?:[Ee][+-]?\\d+)?|NaN|Infinity)\\b/,\n\t// Allow for all non-ASCII characters (See http://stackoverflow.com/a/2008444)\n\t'function': /[_$a-z\\xA0-\\uFFFF][$\\w\\xA0-\\uFFFF]*(?=\\s*\\()/i,\n\t'operator': /-[-=]?|\\+[+=]?|!=?=?|<<?=?|>>?>?=?|=(?:==?|>)?|&[&=]?|\\|[|=]?|\\*\\*?=?|\\/=?|~|\\^=?|%=?|\\?|\\.{3}/\n});\n\nPrism.languages.insertBefore('javascript', 'keyword', {\n\t'regex': {\n\t\tpattern: /(^|[^/])\\/(?!\\/)(\\[[^\\]\\r\\n]+]|\\\\.|[^/\\\\\\[\\r\\n])+\\/[gimyu]{0,5}(?=\\s*($|[\\r\\n,.;})]))/,\n\t\tlookbehind: true,\n\t\tgreedy: true\n\t},\n\t// This must be declared before keyword because we use \"function\" inside the look-forward\n\t'function-variable': {\n\t\tpattern: /[_$a-z\\xA0-\\uFFFF][$\\w\\xA0-\\uFFFF]*(?=\\s*=\\s*(?:function\\b|(?:\\([^()]*\\)|[_$a-z\\xA0-\\uFFFF][$\\w\\xA0-\\uFFFF]*)\\s*=>))/i,\n\t\talias: 'function'\n\t}\n});\n\nPrism.languages.insertBefore('javascript', 'string', {\n\t'template-string': {\n\t\tpattern: /`(?:\\\\[\\s\\S]|[^\\\\`])*`/,\n\t\tgreedy: true,\n\t\tinside: {\n\t\t\t'interpolation': {\n\t\t\t\tpattern: /\\$\\{[^}]+\\}/,\n\t\t\t\tinside: {\n\t\t\t\t\t'interpolation-punctuation': {\n\t\t\t\t\t\tpattern: /^\\$\\{|\\}$/,\n\t\t\t\t\t\talias: 'punctuation'\n\t\t\t\t\t},\n\t\t\t\t\trest: Prism.languages.javascript\n\t\t\t\t}\n\t\t\t},\n\t\t\t'string': /[\\s\\S]+/\n\t\t}\n\t}\n});\n\nif (Prism.languages.markup) {\n\tPrism.languages.insertBefore('markup', 'tag', {\n\t\t'script': {\n\t\t\tpattern: /(<script[\\s\\S]*?>)[\\s\\S]*?(?=<\\/script>)/i,\n\t\t\tlookbehind: true,\n\t\t\tinside: Prism.languages.javascript,\n\t\t\talias: 'language-javascript',\n\t\t\tgreedy: true\n\t\t}\n\t});\n}\n\nPrism.languages.js = Prism.languages.javascript;\n\n\n/* **********************************************\n     Begin prism-file-highlight.js\n********************************************** */\n\n(function () {\n\tif (typeof self === 'undefined' || !self.Prism || !self.document || !document.querySelector) {\n\t\treturn;\n\t}\n\n\tself.Prism.fileHighlight = function() {\n\n\t\tvar Extensions = {\n\t\t\t'js': 'javascript',\n\t\t\t'py': 'python',\n\t\t\t'rb': 'ruby',\n\t\t\t'ps1': 'powershell',\n\t\t\t'psm1': 'powershell',\n\t\t\t'sh': 'bash',\n\t\t\t'bat': 'batch',\n\t\t\t'h': 'c',\n\t\t\t'tex': 'latex'\n\t\t};\n\n\t\tArray.prototype.slice.call(document.querySelectorAll('pre[data-src]')).forEach(function (pre) {\n\t\t\tvar src = pre.getAttribute('data-src');\n\n\t\t\tvar language, parent = pre;\n\t\t\tvar lang = /\\blang(?:uage)?-(?!\\*)(\\w+)\\b/i;\n\t\t\twhile (parent && !lang.test(parent.className)) {\n\t\t\t\tparent = parent.parentNode;\n\t\t\t}\n\n\t\t\tif (parent) {\n\t\t\t\tlanguage = (pre.className.match(lang) || [, ''])[1];\n\t\t\t}\n\n\t\t\tif (!language) {\n\t\t\t\tvar extension = (src.match(/\\.(\\w+)$/) || [, ''])[1];\n\t\t\t\tlanguage = Extensions[extension] || extension;\n\t\t\t}\n\n\t\t\tvar code = document.createElement('code');\n\t\t\tcode.className = 'language-' + language;\n\n\t\t\tpre.textContent = '';\n\n\t\t\tcode.textContent = 'Loading…';\n\n\t\t\tpre.appendChild(code);\n\n\t\t\tvar xhr = new XMLHttpRequest();\n\n\t\t\txhr.open('GET', src, true);\n\n\t\t\txhr.onreadystatechange = function () {\n\t\t\t\tif (xhr.readyState == 4) {\n\n\t\t\t\t\tif (xhr.status < 400 && xhr.responseText) {\n\t\t\t\t\t\tcode.textContent = xhr.responseText;\n\n\t\t\t\t\t\tPrism.highlightElement(code);\n\t\t\t\t\t}\n\t\t\t\t\telse if (xhr.status >= 400) {\n\t\t\t\t\t\tcode.textContent = '✖ Error ' + xhr.status + ' while fetching file: ' + xhr.statusText;\n\t\t\t\t\t}\n\t\t\t\t\telse {\n\t\t\t\t\t\tcode.textContent = '✖ Error: File does not exist or is empty';\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t};\n\n\t\t\txhr.send(null);\n\t\t});\n\n\t};\n\n\tdocument.addEventListener('DOMContentLoaded', self.Prism.fileHighlight);\n\n})();\n"]} +//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["node_modules/browser-pack/_prelude.js","lib/index.js","lib/matchesSelector.js","node_modules/magicpen-prism/lib/magicPenPrism.js","node_modules/magicpen-prism/package.json","node_modules/prismjs/components/prism-csp.js","node_modules/prismjs/components/prism-graphql.js","node_modules/prismjs/prism.js"],"names":[],"mappings":"AAAA;ACAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACn6CA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;ACrBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;ACnHA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACjEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACxBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;ACvBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","file":"generated.js","sourceRoot":"","sourcesContent":["(function(){function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require==\"function\"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error(\"Cannot find module '\"+o+\"'\");throw f.code=\"MODULE_NOT_FOUND\",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require==\"function\"&&require;for(var o=0;o<r.length;o++)s(r[o]);return s}return e})()","/*global DOMParser*/\nvar matchesSelector = require('./matchesSelector');\n\nfunction parseHtml(str, isFragment, assertionNameForErrorMessage) {\n  if (isFragment) {\n    str = '<html><head></head><body>' + str + '</body></html>';\n  }\n  var htmlDocument;\n  if (typeof DOMParser !== 'undefined') {\n    htmlDocument = new DOMParser().parseFromString(str, 'text/html');\n  } else if (\n    typeof document !== 'undefined' &&\n    document.implementation &&\n    document.implementation.createHTMLDocument\n  ) {\n    htmlDocument = document.implementation.createHTMLDocument('');\n    htmlDocument.open();\n    htmlDocument.write(str);\n    htmlDocument.close();\n  } else {\n    var jsdom;\n    try {\n      jsdom = require('' + 'jsdom');\n    } catch (err) {\n      throw new Error(\n        'unexpected-dom' +\n          (assertionNameForErrorMessage\n            ? ' (' + assertionNameForErrorMessage + ')'\n            : '') +\n          ': Running outside a browser, but could not find the `jsdom` module. Please npm install jsdom to make this work.'\n      );\n    }\n    if (jsdom.JSDOM) {\n      htmlDocument = new jsdom.JSDOM(str).window.document;\n    } else {\n      htmlDocument = jsdom.jsdom(str);\n    }\n  }\n  if (isFragment) {\n    var body = htmlDocument.body;\n    var documentFragment = htmlDocument.createDocumentFragment();\n    if (body) {\n      for (var i = 0; i < body.childNodes.length; i += 1) {\n        documentFragment.appendChild(body.childNodes[i].cloneNode(true));\n      }\n    }\n    return documentFragment;\n  } else {\n    return htmlDocument;\n  }\n}\n\nfunction parseXml(str, assertionNameForErrorMessage) {\n  if (typeof DOMParser !== 'undefined') {\n    return new DOMParser().parseFromString(str, 'text/xml');\n  } else {\n    var jsdom;\n    try {\n      jsdom = require('' + 'jsdom');\n    } catch (err) {\n      throw new Error(\n        'unexpected-dom' +\n          (assertionNameForErrorMessage\n            ? ' (' + assertionNameForErrorMessage + ')'\n            : '') +\n          ': Running outside a browser (or in a browser without DOMParser), but could not find the `jsdom` module. Please npm install jsdom to make this work.'\n      );\n    }\n    if (jsdom.JSDOM) {\n      return new jsdom.JSDOM(str, { contentType: 'text/xml' }).window.document;\n    } else {\n      return jsdom.jsdom(str, { parsingMode: 'xml' });\n    }\n  }\n}\n\n// From html-minifier\nvar enumeratedAttributeValues = {\n  draggable: ['true', 'false'] // defaults to 'auto'\n};\n\nfunction isBooleanAttribute(attrName, attrValue) {\n  var isSimpleBoolean = /^(?:allowfullscreen|async|autofocus|autoplay|checked|compact|controls|declare|default|defaultchecked|defaultmuted|defaultselected|defer|disabled|enabled|formnovalidate|hidden|indeterminate|inert|ismap|itemscope|loop|multiple|muted|nohref|noresize|noshade|novalidate|nowrap|open|pauseonexit|readonly|required|reversed|scoped|seamless|selected|sortable|spellcheck|truespeed|typemustmatch|visible)$/i.test(\n    attrName\n  );\n  if (isSimpleBoolean) {\n    return true;\n  }\n\n  var attrValueEnumeration = enumeratedAttributeValues[attrName.toLowerCase()];\n  if (!attrValueEnumeration) {\n    return false;\n  } else {\n    return attrValueEnumeration.indexOf(attrValue.toLowerCase()) === -1;\n  }\n}\n\nfunction styleStringToObject(str) {\n  var styles = {};\n\n  str.split(';').forEach(function(rule) {\n    var tuple = rule.split(':').map(function(part) {\n      return part.trim();\n    });\n\n    // Guard against empty touples\n    if (tuple[0] && tuple[1]) {\n      styles[tuple[0]] = tuple[1];\n    }\n  });\n\n  return styles;\n}\n\nfunction getClassNamesFromAttributeValue(attributeValue) {\n  if (attributeValue === null) {\n    return '';\n  }\n\n  var classNames = attributeValue.split(/\\s+/);\n  if (classNames.length === 1 && classNames[0] === '') {\n    classNames.pop();\n  }\n  return classNames;\n}\n\nfunction isInsideHtmlDocument(node) {\n  var ownerDocument;\n  if (node.nodeType === 9 && node.documentElement && node.implementation) {\n    ownerDocument = node;\n  } else {\n    ownerDocument = node.ownerDocument;\n  }\n  if (ownerDocument.contentType) {\n    return ownerDocument.contentType === 'text/html';\n  } else {\n    return ownerDocument.toString() === '[object HTMLDocument]';\n  }\n}\n\nfunction getAttributes(element) {\n  var isHtml = isInsideHtmlDocument(element);\n  var attrs = element.attributes;\n  var result = {};\n\n  for (var i = 0; i < attrs.length; i += 1) {\n    if (attrs[i].name === 'class') {\n      result[attrs[i].name] =\n        (attrs[i].value && attrs[i].value.split(' ')) || [];\n    } else if (attrs[i].name === 'style') {\n      result[attrs[i].name] = styleStringToObject(attrs[i].value);\n    } else {\n      result[attrs[i].name] =\n        isHtml && isBooleanAttribute(attrs[i].name)\n          ? true\n          : attrs[i].value || '';\n    }\n  }\n\n  return result;\n}\n\nfunction getCanonicalAttributes(element) {\n  var attrs = getAttributes(element);\n  var result = {};\n\n  Object.keys(attrs)\n    .sort()\n    .forEach(function(key) {\n      result[key] = attrs[key];\n    });\n\n  return result;\n}\n\nfunction entitify(value) {\n  return String(value)\n    .replace(/&/g, '&amp;')\n    .replace(/\"/g, '&quot;')\n    .replace(/</g, '&lt;');\n}\n\nfunction isVoidElement(elementName) {\n  return /(?:area|base|br|col|embed|hr|img|input|keygen|link|menuitem|meta|param|source|track|wbr)/i.test(\n    elementName\n  );\n}\n\nfunction writeAttributeToMagicPen(output, attributeName, value, isHtml) {\n  output.prismAttrName(attributeName);\n  if (!isHtml || !isBooleanAttribute(attributeName)) {\n    if (attributeName === 'class') {\n      value = value.join(' ');\n    } else if (attributeName === 'style') {\n      value = Object.keys(value)\n        .map(function(cssProp) {\n          return cssProp + ': ' + value[cssProp];\n        })\n        .join('; ');\n    }\n    output\n      .prismPunctuation('=\"')\n      .prismAttrValue(entitify(value))\n      .prismPunctuation('\"');\n  }\n}\n\nfunction stringifyAttribute(attributeName, value) {\n  if (isBooleanAttribute(attributeName)) {\n    return attributeName;\n  } else if (attributeName === 'class') {\n    return 'class=\"' + value.join(' ') + '\"'; // FIXME: entitify\n  } else if (attributeName === 'style') {\n    return (\n      'style=\"' +\n      Object.keys(value)\n        .map(function(cssProp) {\n          return [cssProp, value[cssProp]].join(': '); // FIXME: entitify\n        })\n        .join('; ') +\n      '\"'\n    );\n  } else {\n    return attributeName + '=\"' + entitify(value) + '\"';\n  }\n}\n\nfunction stringifyStartTag(element) {\n  var elementName =\n    element.ownerDocument.contentType === 'text/html'\n      ? element.nodeName.toLowerCase()\n      : element.nodeName;\n  var str = '<' + elementName;\n  var attrs = getCanonicalAttributes(element);\n\n  Object.keys(attrs).forEach(function(key) {\n    str += ' ' + stringifyAttribute(key, attrs[key]);\n  });\n\n  str += '>';\n  return str;\n}\n\nfunction stringifyEndTag(element) {\n  var isHtml = isInsideHtmlDocument(element);\n  var elementName = isHtml ? element.nodeName.toLowerCase() : element.nodeName;\n  if (isHtml && isVoidElement(elementName) && element.childNodes.length === 0) {\n    return '';\n  } else {\n    return '</' + elementName + '>';\n  }\n}\n\nmodule.exports = {\n  name: 'unexpected-dom',\n  installInto: function(expect) {\n    expect = expect.child();\n    expect.use(require('magicpen-prism'));\n    var topLevelExpect = expect;\n    expect.exportType({\n      name: 'DOMNode',\n      base: 'object',\n      identify: function(obj) {\n        return (\n          obj &&\n          obj.nodeName &&\n          [2, 3, 4, 5, 6, 7, 10, 11, 12].indexOf(obj.nodeType) > -1\n        );\n      },\n      equal: function(a, b) {\n        return a.nodeValue === b.nodeValue;\n      },\n      inspect: function(element, depth, output) {\n        return output.code(\n          element.nodeName + ' \"' + element.nodeValue + '\"',\n          'prism-string'\n        );\n      }\n    });\n\n    expect.exportType({\n      name: 'DOMComment',\n      base: 'DOMNode',\n      identify: function(obj) {\n        return obj && typeof obj.nodeType === 'number' && obj.nodeType === 8;\n      },\n      equal: function(a, b) {\n        return a.nodeValue === b.nodeValue;\n      },\n      inspect: function(element, depth, output) {\n        return output.code('<!--' + element.nodeValue + '-->', 'html');\n      },\n      diff: function(actual, expected, output, diff, inspect, equal) {\n        var d = diff(\n          '<!--' + actual.nodeValue + '-->',\n          '<!--' + expected.nodeValue + '-->'\n        );\n        d.inline = true;\n        return d;\n      }\n    });\n\n    expect.exportType({\n      name: 'DOMTextNode',\n      base: 'DOMNode',\n      identify: function(obj) {\n        return obj && typeof obj.nodeType === 'number' && obj.nodeType === 3;\n      },\n      equal: function(a, b) {\n        return a.nodeValue === b.nodeValue;\n      },\n      inspect: function(element, depth, output) {\n        return output.code(entitify(element.nodeValue.trim()), 'html');\n      },\n      diff: function(actual, expected, output, diff, inspect, equal) {\n        var d = diff(actual.nodeValue, expected.nodeValue);\n        d.inline = true;\n        return d;\n      }\n    });\n\n    expect.exportType({\n      name: 'DOMNodeList',\n      base: 'array-like',\n      prefix: function(output) {\n        return output.text('NodeList[');\n      },\n      suffix: function(output) {\n        return output.text(']');\n      },\n      similar: function(a, b) {\n        // Figure out whether a and b are \"struturally similar\" so they can be diffed inline.\n        return (\n          a.nodeType === 1 && b.nodeType === 1 && a.nodeName === b.nodeName\n        );\n      },\n      identify: function(obj) {\n        return (\n          obj &&\n          typeof obj.length === 'number' &&\n          typeof obj.toString === 'function' &&\n          typeof obj.item === 'function' &&\n          // With jsdom 6+, nodeList.toString() comes out as '[object Object]', so fall back to the constructor name:\n          (obj.toString().indexOf('NodeList') !== -1 ||\n            (obj.constructor && obj.constructor.name === 'NodeList'))\n        );\n      }\n    });\n\n    // Fake type to make it possible to build 'to satisfy' diffs to be rendered inline:\n    expect.exportType({\n      name: 'attachedDOMNodeList',\n      base: 'DOMNodeList',\n      indent: false,\n      prefix: function(output) {\n        return output;\n      },\n      suffix: function(output) {\n        return output;\n      },\n      delimiter: function(output) {\n        return output;\n      },\n      identify: function(obj) {\n        return obj && obj._isAttachedDOMNodeList;\n      }\n    });\n\n    function makeAttachedDOMNodeList(domNodeList, contentType) {\n      var attachedDOMNodeList = [];\n      for (var i = 0; i < domNodeList.length; i += 1) {\n        attachedDOMNodeList.push(domNodeList[i]);\n      }\n      attachedDOMNodeList._isAttachedDOMNodeList = true;\n      attachedDOMNodeList.ownerDocument = { contentType: contentType };\n      return attachedDOMNodeList;\n    }\n\n    expect.exportType({\n      name: 'HTMLDocType',\n      base: 'DOMNode',\n      identify: function(obj) {\n        return (\n          obj &&\n          typeof obj.nodeType === 'number' &&\n          obj.nodeType === 10 &&\n          'publicId' in obj\n        );\n      },\n      inspect: function(doctype, depth, output, inspect) {\n        return output.code('<!DOCTYPE ' + doctype.name + '>', 'html');\n      },\n      equal: function(a, b) {\n        return a.toString() === b.toString();\n      },\n      diff: function(actual, expected, output, diff) {\n        var d = diff(\n          '<!DOCTYPE ' + actual.name + '>',\n          '<!DOCTYPE ' + expected.name + '>'\n        );\n        d.inline = true;\n        return d;\n      }\n    });\n\n    expect.exportType({\n      name: 'DOMDocument',\n      base: 'DOMNode',\n      identify: function(obj) {\n        return (\n          obj &&\n          typeof obj.nodeType === 'number' &&\n          obj.nodeType === 9 &&\n          obj.documentElement &&\n          obj.implementation\n        );\n      },\n      inspect: function(document, depth, output, inspect) {\n        for (var i = 0; i < document.childNodes.length; i += 1) {\n          output.append(inspect(document.childNodes[i]));\n        }\n        return output;\n      },\n      diff: function(actual, expected, output, diff, inspect, equal) {\n        output.inline = true;\n        output.append(\n          diff(\n            makeAttachedDOMNodeList(actual.childNodes),\n            makeAttachedDOMNodeList(expected.childNodes)\n          ).diff\n        );\n        return output;\n      }\n    });\n\n    expect.exportType({\n      name: 'HTMLDocument',\n      base: 'DOMDocument',\n      identify: function(obj) {\n        return this.baseType.identify(obj) && obj.contentType === 'text/html';\n      }\n    });\n\n    expect.exportType({\n      name: 'XMLDocument',\n      base: 'DOMDocument',\n      identify: function(obj) {\n        return (\n          this.baseType.identify(obj) &&\n          /^(?:application|text)\\/xml|\\+xml\\b/.test(obj.contentType)\n        );\n      },\n      inspect: function(document, depth, output, inspect) {\n        output.code('<?xml version=\"1.0\"?>', 'xml');\n        for (var i = 0; i < document.childNodes.length; i += 1) {\n          output.append(inspect(document.childNodes[i], depth - 1));\n        }\n        return output;\n      }\n    });\n\n    expect.exportType({\n      name: 'DOMDocumentFragment',\n      base: 'DOMNode',\n      identify: function(obj) {\n        return obj && obj.nodeType === 11; // In jsdom, documentFragment.toString() does not return [object DocumentFragment]\n      },\n      inspect: function(documentFragment, depth, output, inspect) {\n        return output\n          .text('DocumentFragment[')\n          .append(inspect(documentFragment.childNodes, depth))\n          .text(']');\n      },\n      diff: function(actual, expected, output, diff, inspect, equal) {\n        output.inline = true;\n        output.block(\n          diff(\n            makeAttachedDOMNodeList(actual.childNodes),\n            makeAttachedDOMNodeList(expected.childNodes)\n          ).diff\n        );\n        return output;\n      }\n    });\n\n    expect.exportType({\n      name: 'DOMElement',\n      base: 'DOMNode',\n      identify: function(obj) {\n        return (\n          obj &&\n          typeof obj.nodeType === 'number' &&\n          obj.nodeType === 1 &&\n          obj.nodeName &&\n          obj.attributes\n        );\n      },\n      equal: function(a, b, equal) {\n        var aIsHtml = isInsideHtmlDocument(a);\n        var bIsHtml = isInsideHtmlDocument(b);\n        return (\n          aIsHtml === bIsHtml &&\n          (aIsHtml\n            ? a.nodeName.toLowerCase() === b.nodeName.toLowerCase()\n            : a.nodeName === b.nodeName) &&\n          equal(getAttributes(a), getAttributes(b)) &&\n          equal(a.childNodes, b.childNodes)\n        );\n      },\n      inspect: function(element, depth, output, inspect) {\n        var elementName = element.nodeName.toLowerCase();\n        var startTag = stringifyStartTag(element);\n\n        output.code(startTag, 'html');\n        if (element.childNodes.length > 0) {\n          if (depth === 1) {\n            output.text('...');\n          } else {\n            var inspectedChildren = [];\n            if (elementName === 'script') {\n              var type = element.getAttribute('type');\n              if (!type || /javascript/.test(type)) {\n                type = 'javascript';\n              }\n              inspectedChildren.push(\n                output.clone().code(element.textContent, type)\n              );\n            } else if (elementName === 'style') {\n              inspectedChildren.push(\n                output\n                  .clone()\n                  .code(\n                    element.textContent,\n                    element.getAttribute('type') || 'text/css'\n                  )\n              );\n            } else {\n              for (var i = 0; i < element.childNodes.length; i += 1) {\n                inspectedChildren.push(inspect(element.childNodes[i]));\n              }\n            }\n\n            var width = startTag.length;\n            var multipleLines = inspectedChildren.some(function(o) {\n              var size = o.size();\n              width += size.width;\n              return width > 60 || o.height > 1;\n            });\n\n            if (multipleLines) {\n              output.nl().indentLines();\n\n              inspectedChildren.forEach(function(inspectedChild, index) {\n                output\n                  .i()\n                  .block(inspectedChild)\n                  .nl();\n              });\n\n              output.outdentLines();\n            } else {\n              inspectedChildren.forEach(function(inspectedChild, index) {\n                output.append(inspectedChild);\n              });\n            }\n          }\n        }\n        output.code(stringifyEndTag(element), 'html');\n        return output;\n      },\n      diffLimit: 512,\n      diff: function(actual, expected, output, diff, inspect, equal) {\n        var isHtml = isInsideHtmlDocument(actual);\n        output.inline = true;\n\n        if (Math.max(actual.length, expected.length) > this.diffLimit) {\n          output.jsComment('Diff suppressed due to size > ' + this.diffLimit);\n          return output;\n        }\n\n        var emptyElements =\n          actual.childNodes.length === 0 && expected.childNodes.length === 0;\n        var conflictingElement =\n          actual.nodeName.toLowerCase() !== expected.nodeName.toLowerCase() ||\n          !equal(getAttributes(actual), getAttributes(expected));\n\n        if (conflictingElement) {\n          var canContinueLine = true;\n          output.prismPunctuation('<').prismTag(actual.nodeName.toLowerCase());\n          if (\n            actual.nodeName.toLowerCase() !== expected.nodeName.toLowerCase()\n          ) {\n            output\n              .sp()\n              .annotationBlock(function() {\n                this.error('should be')\n                  .sp()\n                  .prismTag(expected.nodeName.toLowerCase());\n              })\n              .nl();\n            canContinueLine = false;\n          }\n          var actualAttributes = getAttributes(actual);\n          var expectedAttributes = getAttributes(expected);\n          Object.keys(actualAttributes).forEach(function(attributeName) {\n            output.sp(canContinueLine ? 1 : 2 + actual.nodeName.length);\n            writeAttributeToMagicPen(\n              output,\n              attributeName,\n              actualAttributes[attributeName],\n              isHtml\n            );\n            if (attributeName in expectedAttributes) {\n              if (\n                actualAttributes[attributeName] ===\n                expectedAttributes[attributeName]\n              ) {\n                canContinueLine = true;\n              } else {\n                output\n                  .sp()\n                  .annotationBlock(function() {\n                    this.error('should equal')\n                      .sp()\n                      .append(\n                        inspect(entitify(expectedAttributes[attributeName]))\n                      );\n                  })\n                  .nl();\n                canContinueLine = false;\n              }\n              delete expectedAttributes[attributeName];\n            } else {\n              output\n                .sp()\n                .annotationBlock(function() {\n                  this.error('should be removed');\n                })\n                .nl();\n              canContinueLine = false;\n            }\n          });\n          Object.keys(expectedAttributes).forEach(function(attributeName) {\n            output.sp(canContinueLine ? 1 : 2 + actual.nodeName.length);\n            output\n              .annotationBlock(function() {\n                this.error('missing').sp();\n                writeAttributeToMagicPen(\n                  this,\n                  attributeName,\n                  expectedAttributes[attributeName],\n                  isHtml\n                );\n              })\n              .nl();\n            canContinueLine = false;\n          });\n          output.prismPunctuation('>');\n        } else {\n          output.code(stringifyStartTag(actual), 'html');\n        }\n\n        if (!emptyElements) {\n          output\n            .nl()\n            .indentLines()\n            .i()\n            .block(\n              diff(\n                makeAttachedDOMNodeList(actual.childNodes),\n                makeAttachedDOMNodeList(expected.childNodes)\n              ).diff\n            )\n            .nl()\n            .outdentLines();\n        }\n\n        output.code(stringifyEndTag(actual), 'html');\n        return output;\n      }\n    });\n\n    expect.exportAssertion(\n      '<DOMElement> to have (class|classes) <array|string>',\n      function(expect, subject, value) {\n        return expect(subject, 'to have attributes', { class: value });\n      }\n    );\n\n    expect.exportAssertion(\n      '<DOMElement> to only have (class|classes) <array|string>',\n      function(expect, subject, value) {\n        return expect(subject, 'to have attributes', {\n          class: function(className) {\n            var actualClasses = getClassNamesFromAttributeValue(className);\n            if (typeof value === 'string') {\n              value = getClassNamesFromAttributeValue(value);\n            }\n            return topLevelExpect(\n              actualClasses.sort(),\n              'to equal',\n              value.sort()\n            );\n          }\n        });\n      }\n    );\n\n    expect.exportAssertion(\n      '<DOMTextNode> to [exhaustively] satisfy <DOMTextNode>',\n      function(expect, subject, value) {\n        return expect(subject.nodeValue, 'to equal', value.nodeValue);\n      }\n    );\n\n    // Avoid rendering a huge object diff when a text node is matched against a different node type:\n    expect.exportAssertion(\n      '<DOMTextNode> to [exhaustively] satisfy <object>',\n      function(expect, subject, value) {\n        expect.fail();\n      }\n    );\n\n    // Necessary because this case would otherwise be handled by the above catch-all for <object>:\n    expect.exportAssertion(\n      '<DOMTextNode> to [exhaustively] satisfy <regexp>',\n      function(expect, subject, value) {\n        return expect(subject.nodeValue, 'to satisfy', value);\n      }\n    );\n\n    expect.exportAssertion(\n      '<DOMTextNode> to [exhaustively] satisfy <any>',\n      function(expect, subject, value) {\n        return expect(subject.nodeValue, 'to satisfy', value);\n      }\n    );\n\n    function convertDOMNodeToSatisfySpec(node, isHtml) {\n      if (node.nodeType === 8 && node.nodeValue.trim() === 'ignore') {\n        // Ignore subtree\n        return {};\n      } else if (node.nodeType === 10) {\n        // HTMLDocType\n        return { name: node.nodeName };\n      } else if (node.nodeType === 1) {\n        // DOMElement\n        var name = isHtml ? node.nodeName.toLowerCase() : node.nodeName;\n\n        if (name === 'ignore') {\n          // Ignore subtree\n          return {};\n        }\n\n        var result = { name: name };\n\n        if (node.attributes) {\n          result.attributes = {};\n          for (var i = 0; i < node.attributes.length; i += 1) {\n            result.attributes[node.attributes[i].name] =\n              isHtml && isBooleanAttribute(node.attributes[i].name)\n                ? true\n                : node.attributes[i].value || '';\n          }\n        }\n        result.children = Array.prototype.map.call(node.childNodes, function(\n          childNode\n        ) {\n          return convertDOMNodeToSatisfySpec(childNode, isHtml);\n        });\n        return result;\n      } else if (node.nodeType === 3) {\n        // DOMTextNode\n        return node.nodeValue;\n      } else {\n        throw new Error(\n          'to satisfy: Node type ' +\n            node.nodeType +\n            ' is not yet supported in the value'\n        );\n      }\n    }\n\n    expect.exportAssertion(\n      '<DOMNodeList> to [exhaustively] satisfy <string>',\n      function(expect, subject, value) {\n        var isHtml = subject.ownerDocument.contentType === 'text/html';\n        expect.argsOutput = function(output) {\n          return output.code(value, isHtml ? 'html' : 'xml');\n        };\n        return expect(\n          subject,\n          'to [exhaustively] satisfy',\n          (isHtml\n            ? parseHtml(value, true, expect.testDescription)\n            : parseXml(value, expect.testDescription)\n          ).childNodes\n        );\n      }\n    );\n\n    expect.exportAssertion(\n      '<DOMNodeList> to [exhaustively] satisfy <DOMNodeList>',\n      function(expect, subject, value) {\n        var isHtml = subject.ownerDocument.contentType === 'text/html';\n        var satisfySpecs = [];\n        for (var i = 0; i < value.length; i += 1) {\n          satisfySpecs.push(convertDOMNodeToSatisfySpec(value[i], isHtml));\n        }\n        return expect(subject, 'to [exhaustively] satisfy', satisfySpecs);\n      }\n    );\n\n    expect.exportAssertion(\n      '<DOMDocumentFragment> to [exhaustively] satisfy <string>',\n      function(expect, subject, value) {\n        var isHtml = isInsideHtmlDocument(subject);\n        expect.argsOutput = function(output) {\n          return output.code(value, isHtml ? 'html' : 'xml');\n        };\n        return expect(\n          subject,\n          'to [exhaustively] satisfy',\n          isHtml\n            ? parseHtml(value, true, expect.testDescription)\n            : parseXml(value, expect.testDescription)\n        );\n      }\n    );\n\n    expect.exportAssertion(\n      '<DOMDocumentFragment> to [exhaustively] satisfy <DOMDocumentFragment>',\n      function(expect, subject, value) {\n        var isHtml = subject.ownerDocument.contentType === 'text/html';\n        return expect(\n          subject,\n          'to [exhaustively] satisfy',\n          Array.prototype.map.call(value.childNodes, function(childNode) {\n            return convertDOMNodeToSatisfySpec(childNode, isHtml);\n          })\n        );\n      }\n    );\n\n    expect.exportAssertion(\n      '<DOMDocumentFragment> to [exhaustively] satisfy <object|array>',\n      function(expect, subject, value) {\n        return expect(subject.childNodes, 'to [exhaustively] satisfy', value);\n      }\n    );\n\n    expect.exportAssertion(\n      '<DOMElement> to [exhaustively] satisfy <string>',\n      function(expect, subject, value) {\n        var isHtml = isInsideHtmlDocument(subject);\n        var documentFragment = isHtml\n          ? parseHtml(value, true, this.testDescription)\n          : parseXml(value, this.testDescription);\n        if (documentFragment.childNodes.length !== 1) {\n          throw new Error(\n            'HTMLElement to satisfy string: Only a single node is supported'\n          );\n        }\n        expect.argsOutput = function(output) {\n          return output.code(value, isHtml ? 'html' : 'xml');\n        };\n        return expect(\n          subject,\n          'to [exhaustively] satisfy',\n          documentFragment.childNodes[0]\n        );\n      }\n    );\n\n    expect.exportAssertion(\n      '<DOMDocument> to [exhaustively] satisfy <string>',\n      function(expect, subject, value) {\n        var isHtml = isInsideHtmlDocument(subject);\n        var valueDocument = isHtml\n          ? parseHtml(value, false, this.testDescription)\n          : parseXml(value, this.testDescription);\n        return expect(\n          makeAttachedDOMNodeList(subject.childNodes),\n          'to [exhaustively] satisfy',\n          Array.prototype.map.call(valueDocument.childNodes, function(\n            childNode\n          ) {\n            return convertDOMNodeToSatisfySpec(childNode, isHtml);\n          })\n        );\n      }\n    );\n\n    expect.exportAssertion(\n      '<DOMDocument> to [exhaustively] satisfy <DOMDocument>',\n      function(expect, subject, value) {\n        var isHtml = isInsideHtmlDocument(subject);\n        return expect(\n          makeAttachedDOMNodeList(subject.childNodes),\n          'to [exhaustively] satisfy',\n          Array.prototype.map.call(value.childNodes, function(childNode) {\n            return convertDOMNodeToSatisfySpec(childNode, isHtml);\n          })\n        );\n      }\n    );\n\n    expect.exportAssertion(\n      '<DOMElement> to [exhaustively] satisfy <DOMElement>',\n      function(expect, subject, value) {\n        return expect(\n          subject,\n          'to [exhaustively] satisfy',\n          convertDOMNodeToSatisfySpec(value, isInsideHtmlDocument(subject))\n        );\n      }\n    );\n\n    expect.exportAssertion(\n      '<DOMElement> to [exhaustively] satisfy <DOMTextNode>',\n      function(expect, subject, value) {\n        expect.fail();\n      }\n    );\n\n    expect.exportAssertion(\n      '<DOMTextNode> to [exhaustively] satisfy <DOMElement>',\n      function(expect, subject, value) {\n        expect.fail();\n      }\n    );\n\n    expect.exportAssertion(\n      '<DOMElement> to [exhaustively] satisfy <object>',\n      function(expect, subject, value) {\n        var isHtml = isInsideHtmlDocument(subject);\n        var unsupportedOptions = Object.keys(value).filter(function(key) {\n          return (\n            key !== 'attributes' &&\n            key !== 'name' &&\n            key !== 'children' &&\n            key !== 'onlyAttributes' &&\n            key !== 'textContent'\n          );\n        });\n        if (unsupportedOptions.length > 0) {\n          throw new Error(\n            'Unsupported option' +\n              (unsupportedOptions.length === 1 ? '' : 's') +\n              ': ' +\n              unsupportedOptions.join(', ')\n          );\n        }\n\n        var promiseByKey = {\n          name: expect.promise(function() {\n            if (value && typeof value.name !== 'undefined') {\n              return topLevelExpect(\n                isHtml ? subject.nodeName.toLowerCase() : subject.nodeName,\n                'to satisfy',\n                value.name\n              );\n            }\n          }),\n          children: expect.promise(function() {\n            if (typeof value.children !== 'undefined') {\n              if (typeof value.textContent !== 'undefined') {\n                throw new Error(\n                  'The children and textContent properties are not supported together'\n                );\n              }\n              return topLevelExpect(\n                makeAttachedDOMNodeList(\n                  subject.childNodes,\n                  subject.ownerDocument.contentType\n                ),\n                'to satisfy',\n                value.children\n              );\n            } else if (typeof value.textContent !== 'undefined') {\n              return topLevelExpect(\n                subject.textContent,\n                'to satisfy',\n                value.textContent\n              );\n            }\n          }),\n          attributes: {}\n        };\n\n        var onlyAttributes =\n          (value && value.onlyAttributes) || expect.flags.exhaustively;\n        var attrs = getAttributes(subject);\n        var expectedAttributes = value && value.attributes;\n        var expectedAttributeNames = [];\n\n        if (typeof expectedAttributes !== 'undefined') {\n          if (typeof expectedAttributes === 'string') {\n            expectedAttributes = [expectedAttributes];\n          }\n          var expectedValueByAttributeName = {};\n          if (Array.isArray(expectedAttributes)) {\n            expectedAttributes.forEach(function(attributeName) {\n              expectedValueByAttributeName[attributeName] = true;\n            });\n          } else if (\n            expectedAttributes &&\n            typeof expectedAttributes === 'object'\n          ) {\n            expectedValueByAttributeName = expectedAttributes;\n          }\n          Object.keys(expectedValueByAttributeName).forEach(function(\n            attributeName\n          ) {\n            expectedAttributeNames.push(attributeName);\n          });\n\n          expectedAttributeNames.forEach(function(attributeName) {\n            var attributeValue = subject.getAttribute(attributeName);\n            var expectedAttributeValue =\n              expectedValueByAttributeName[attributeName];\n            promiseByKey.attributes[attributeName] = expect.promise(function() {\n              if (expectedAttributeValue === true) {\n                topLevelExpect(\n                  subject.hasAttribute(attributeName),\n                  'to be true'\n                );\n              } else if (typeof expectedAttributeValue === 'undefined') {\n                topLevelExpect(\n                  subject.hasAttribute(attributeName),\n                  'to be false'\n                );\n              } else if (\n                attributeName === 'class' &&\n                (typeof expectedAttributeValue === 'string' ||\n                  Array.isArray(expectedAttributeValue))\n              ) {\n                var actualClasses = getClassNamesFromAttributeValue(\n                  attributeValue\n                );\n                var expectedClasses = expectedAttributeValue;\n                if (typeof expectedClasses === 'string') {\n                  expectedClasses = getClassNamesFromAttributeValue(\n                    expectedAttributeValue\n                  );\n                }\n                if (onlyAttributes) {\n                  return topLevelExpect(\n                    actualClasses.sort(),\n                    'to equal',\n                    expectedClasses.sort()\n                  );\n                } else {\n                  return topLevelExpect.apply(\n                    topLevelExpect,\n                    [actualClasses, 'to contain'].concat(expectedClasses)\n                  );\n                }\n              } else if (attributeName === 'style') {\n                var expectedStyleObj;\n                if (typeof expectedValueByAttributeName.style === 'string') {\n                  expectedStyleObj = styleStringToObject(\n                    expectedValueByAttributeName.style\n                  );\n                } else {\n                  expectedStyleObj = expectedValueByAttributeName.style;\n                }\n\n                if (onlyAttributes) {\n                  return topLevelExpect(\n                    attrs.style,\n                    'to exhaustively satisfy',\n                    expectedStyleObj\n                  );\n                } else {\n                  return topLevelExpect(\n                    attrs.style,\n                    'to satisfy',\n                    expectedStyleObj\n                  );\n                }\n              } else {\n                return topLevelExpect(\n                  attributeValue,\n                  'to satisfy',\n                  expectedAttributeValue\n                );\n              }\n            });\n          });\n\n          promiseByKey.attributePresence = expect.promise(function() {\n            var attributeNamesExpectedToBeDefined = [];\n            expectedAttributeNames.forEach(function(attributeName) {\n              if (\n                typeof expectedValueByAttributeName[attributeName] ===\n                'undefined'\n              ) {\n                expect(attrs, 'not to have key', attributeName);\n              } else {\n                attributeNamesExpectedToBeDefined.push(attributeName);\n                expect(attrs, 'to have key', attributeName);\n              }\n            });\n            if (onlyAttributes) {\n              expect(\n                Object.keys(attrs).sort(),\n                'to equal',\n                attributeNamesExpectedToBeDefined.sort()\n              );\n            }\n          });\n        }\n\n        return expect.promise.all(promiseByKey).caught(function() {\n          return expect.promise.settle(promiseByKey).then(function() {\n            expect.fail({\n              diff: function(output, diff, inspect, equal) {\n                output.block(function() {\n                  var output = this;\n                  var seenError = false;\n                  output\n                    .prismPunctuation('<')\n                    .prismTag(\n                      isHtml ? subject.nodeName.toLowerCase() : subject.nodeName\n                    );\n                  if (promiseByKey.name.isRejected()) {\n                    seenError = true;\n                    var nameError = promiseByKey.name.reason();\n                    output.sp().annotationBlock(function() {\n                      this.error(\n                        (nameError && nameError.getLabel()) || 'should satisfy'\n                      )\n                        .sp()\n                        .append(inspect(value.name));\n                    });\n                  }\n                  var inspectedAttributes = [];\n                  Object.keys(attrs).forEach(function(attributeName) {\n                    var attributeOutput = output.clone();\n                    var promise = promiseByKey.attributes[attributeName];\n                    writeAttributeToMagicPen(\n                      attributeOutput,\n                      attributeName,\n                      attrs[attributeName],\n                      isHtml\n                    );\n                    if (\n                      (promise && promise.isFulfilled()) ||\n                      (!promise &&\n                        (!onlyAttributes ||\n                          expectedAttributeNames.indexOf(attributeName) !== -1))\n                    ) {\n                    } else {\n                      seenError = true;\n                      attributeOutput.sp().annotationBlock(function() {\n                        if (\n                          promise &&\n                          typeof expectedValueByAttributeName[attributeName] !==\n                            'undefined'\n                        ) {\n                          this.append(promise.reason().getErrorMessage(this));\n                        } else {\n                          // onlyAttributes === true\n                          this.error('should be removed');\n                        }\n                      });\n                    }\n                    inspectedAttributes.push(attributeOutput);\n                  });\n                  expectedAttributeNames.forEach(function(attributeName) {\n                    if (!subject.hasAttribute(attributeName)) {\n                      var promise = promiseByKey.attributes[attributeName];\n                      if (!promise || promise.isRejected()) {\n                        seenError = true;\n                        var err = promise && promise.reason();\n                        var attributeOutput = output\n                          .clone()\n                          .annotationBlock(function() {\n                            this.error('missing')\n                              .sp()\n                              .prismAttrName(attributeName, 'html');\n                            if (\n                              expectedValueByAttributeName[attributeName] !==\n                              true\n                            ) {\n                              this.sp()\n                                .error(\n                                  (err && err.getLabel()) || 'should satisfy'\n                                )\n                                .sp()\n                                .append(\n                                  inspect(\n                                    expectedValueByAttributeName[attributeName]\n                                  )\n                                );\n                            }\n                          });\n                        inspectedAttributes.push(attributeOutput);\n                      }\n                    }\n                  });\n                  if (inspectedAttributes.length > 0) {\n                    if (seenError) {\n                      output\n                        .nl()\n                        .indentLines()\n                        .indent()\n                        .block(function(output) {\n                          inspectedAttributes.forEach(function(item, i) {\n                            if (i > 0) {\n                              output.nl();\n                            }\n                            output.append(item);\n                          });\n                        })\n                        .outdentLines()\n                        .nl();\n                    } else {\n                      output.sp();\n                      inspectedAttributes.forEach(function(item, i) {\n                        if (i > 0) {\n                          output.sp();\n                        }\n                        output.append(item);\n                      });\n                    }\n                  } else if (seenError) {\n                    // The tag name mismatched\n                    output.nl();\n                  }\n\n                  output.prismPunctuation('>');\n                  var childrenError =\n                    promiseByKey.children.isRejected() &&\n                    promiseByKey.children.reason();\n                  if (childrenError) {\n                    var childrenDiff = childrenError.getDiff(output);\n                    if (childrenDiff && childrenDiff.inline) {\n                      this.nl()\n                        .indentLines()\n                        .i()\n                        .block(childrenDiff.diff)\n                        .nl()\n                        .outdentLines();\n                    } else {\n                      output\n                        .nl()\n                        .indentLines()\n                        .i()\n                        .block(function() {\n                          for (\n                            var i = 0;\n                            i < subject.childNodes.length;\n                            i += 1\n                          ) {\n                            this.append(inspect(subject.childNodes[i])).nl();\n                          }\n                        });\n                      output.sp().annotationBlock(function() {\n                        this.append(childrenError.getErrorMessage(this));\n                      });\n                      output.nl();\n                    }\n                  } else {\n                    for (var i = 0; i < subject.childNodes.length; i += 1) {\n                      this.append(inspect(subject.childNodes[i]));\n                    }\n                  }\n                  output.code(stringifyEndTag(subject), 'html');\n                });\n                output.inline = true;\n                return output;\n              }\n            });\n          });\n        });\n      }\n    );\n\n    expect.exportAssertion(\n      '<DOMElement> to [only] have (attribute|attributes) <string+>',\n      function(expect, subject, value) {\n        return expect(\n          subject,\n          'to [only] have attributes',\n          Array.prototype.slice.call(arguments, 2)\n        );\n      }\n    );\n\n    expect.exportAssertion(\n      '<DOMElement> not to have (attribute|attributes) <array>',\n      function(expect, subject, value) {\n        var attributes = getAttributes(subject);\n\n        value.forEach(function(name) {\n          delete attributes[name];\n        });\n\n        return expect(subject, 'to only have attributes', attributes);\n      }\n    );\n\n    expect.exportAssertion(\n      '<DOMElement> not to have (attribute|attributes) <string+>',\n      function(expect, subject, value) {\n        return expect(\n          subject,\n          'not to have attributes',\n          Array.prototype.slice.call(arguments, 2)\n        );\n      }\n    );\n\n    expect.exportAssertion(\n      '<DOMElement> to [only] have (attribute|attributes) <array|object>',\n      function(expect, subject, value) {\n        return expect(subject, 'to satisfy', {\n          attributes: value,\n          onlyAttributes: expect.flags.only\n        });\n      }\n    );\n\n    expect.exportAssertion('<DOMElement> to have no (child|children)', function(\n      expect,\n      subject\n    ) {\n      expect.errorMode = 'nested';\n      return expect(\n        Array.prototype.slice.call(subject.childNodes),\n        'to be an empty array'\n      );\n    });\n\n    expect.exportAssertion('<DOMElement> to have (child|children)', function(\n      expect,\n      subject\n    ) {\n      return expect(subject.childNodes, 'not to be empty');\n    });\n\n    expect.exportAssertion(\n      '<DOMElement> to have (child|children) <string>',\n      function(expect, subject, query) {\n        expect.errorMode = 'nested';\n        expect(subject.querySelectorAll(query), 'not to be empty');\n      }\n    );\n\n    expect.exportAssertion('<DOMElement> to have text <any>', function(\n      expect,\n      subject,\n      value\n    ) {\n      return expect(subject.textContent, 'to satisfy', value);\n    });\n\n    expect.exportAssertion(\n      '<DOMDocument|DOMElement|DOMDocumentFragment> [when] queried for [first] <string> <assertion?>',\n      function(expect, subject, query) {\n        var queryResult;\n\n        expect.argsOutput[0] = function(output) {\n          return output.green(query);\n        };\n\n        expect.errorMode = 'nested';\n\n        if (expect.flags.first) {\n          queryResult = subject.querySelector(query);\n          if (!queryResult) {\n            expect.fail(function(output) {\n              return output\n                .error('The selector')\n                .sp()\n                .jsString(query)\n                .sp()\n                .error('yielded no results');\n            });\n          }\n        } else {\n          queryResult = subject.querySelectorAll(query);\n          if (queryResult.length === 0) {\n            expect.fail(function(output) {\n              return output\n                .error('The selector')\n                .sp()\n                .jsString(query)\n                .sp()\n                .error('yielded no results');\n            });\n          }\n        }\n        return expect.shift(queryResult);\n      }\n    );\n\n    expect.exportAssertion(\n      '<DOMDocument|DOMElement|DOMDocumentFragment> to contain [no] elements matching <string>',\n      function(expect, subject, query) {\n        if (expect.flags.no) {\n          return expect(subject.querySelectorAll(query), 'to satisfy', []);\n        }\n\n        expect.subjectOutput = function(output) {\n          expect.inspect(subject, Infinity, output);\n        };\n        return expect(subject.querySelectorAll(query), 'not to satisfy', []);\n      }\n    );\n\n    expect.exportAssertion(\n      '<DOMDocument|DOMElement|DOMDocumentFragment> [not] to match <string>',\n      function(expect, subject, query) {\n        return expect(\n          matchesSelector(subject, query),\n          'to be',\n          !expect.flags.not\n        );\n      }\n    );\n\n    expect.exportAssertion(\n      '<string> [when] parsed as (html|HTML) [fragment] <assertion?>',\n      function(expect, subject) {\n        expect.errorMode = 'nested';\n        return expect.shift(\n          parseHtml(subject, expect.flags.fragment, expect.testDescription)\n        );\n      }\n    );\n\n    expect.exportAssertion(\n      '<string> [when] parsed as (xml|XML) <assertion?>',\n      function(expect, subject) {\n        expect.errorMode = 'nested';\n        return expect.shift(parseXml(subject, expect.testDescription));\n      }\n    );\n  }\n};\n","module.exports = function(elm, selector) {\n  var matchFuntion =\n    elm.matchesSelector ||\n    elm.mozMatchesSelector ||\n    elm.msMatchesSelector ||\n    elm.oMatchesSelector ||\n    elm.webkitMatchesSelector ||\n    function(selector) {\n      var node = this;\n      var nodes = (node.parentNode || node.document).querySelectorAll(selector);\n      var i = 0;\n\n      while (nodes[i] && nodes[i] !== node) {\n        i += 1;\n      }\n\n      return !!nodes[i];\n    };\n\n  return matchFuntion.call(elm, selector);\n};\n","var oldPrismGlobal = global.Prism;\nvar prism = global.Prism = require('prismjs');\nrequire('prismjs/components/prism-graphql.js');\nrequire('prismjs/components/prism-csp.js');\nglobal.Prism = oldPrismGlobal;\n\nvar defaultTheme = {\n    // Adapted from the default Prism theme:\n    prismComment: '#708090', // slategray\n    prismProlog: 'prismComment',\n    prismDoctype: 'prismComment',\n    prismCdata: 'prismComment',\n\n    prismPunctuation: '#999',\n\n    prismSymbol: '#905',\n    prismProperty: 'prismSymbol',\n    prismTag: 'prismSymbol',\n    prismBoolean: 'prismSymbol',\n    prismNumber: 'prismSymbol',\n    prismConstant: 'prismSymbol',\n    prismDeleted: 'prismSymbol',\n\n    prismString: '#690',\n    prismSelector: 'prismString',\n    prismAttrName: 'prismString',\n    prismChar: 'prismString',\n    prismBuiltin: 'prismString',\n    prismInserted: 'prismString',\n\n    prismOperator: '#a67f59',\n    prismVariable: 'prismOperator',\n    prismEntity: 'prismOperator',\n    prismUrl: 'prismOperator',\n    prismCssString: 'prismOperator',\n\n    prismKeyword: '#07a',\n    prismAtrule: 'prismKeyword',\n    prismAttrValue: 'prismKeyword',\n\n    prismFunction: '#DD4A68',\n\n    prismRegex: '#e90',\n    prismImportant: ['#e90', 'bold']\n};\n\nvar languageMapping = {\n    'text/html': 'markup',\n    'application/xml': 'markup',\n    'text/xml': 'markup',\n    'application/json': 'javascript',\n    'text/javascript': 'javascript',\n    'application/javascript': 'javascript',\n    'text/css': 'css',\n    html: 'markup',\n    xml: 'markup',\n    c: 'clike',\n    'c++': 'clike',\n    'cpp': 'clike',\n    'c#': 'clike',\n    java: 'clike',\n    'application/graphql': 'graphql'\n};\n\nfunction upperCamelCase(str) {\n    return str.replace(/(?:^|-)([a-z])/g, function ($0, ch) {\n        return ch.toUpperCase();\n    });\n}\n\nmodule.exports = {\n    name: 'magicpen-prism',\n    version: require('../package.json').version,\n    installInto: function (magicPen) {\n        magicPen.installTheme(defaultTheme);\n\n        magicPen.addStyle('code', function (sourceText, language) {\n            if (language in languageMapping) {\n                language = languageMapping[language];\n            } else if (/\\+xml\\b/.test(language)) {\n                language = 'markup';\n            }\n            if (!(language in prism.languages)) {\n                return this.text(sourceText);\n            }\n\n            var that = this;\n            var capitalizedLanguage = upperCamelCase(language);\n            var languageDefinition = prism.languages[language];\n\n            function printTokens(token, parentStyle) {\n                if (Array.isArray(token)) {\n                    token.forEach(function (subToken) {\n                        printTokens(subToken, parentStyle);\n                    });\n                } else if (typeof token === 'string') {\n                    var upperCamelCasedParentStyle = upperCamelCase(parentStyle);\n                    token = token.replace(/&lt;/g, '<');\n                    if (that['prism' + capitalizedLanguage + upperCamelCasedParentStyle]) {\n                        that['prism' + capitalizedLanguage + upperCamelCasedParentStyle](token);\n                    } else if (that['prism' + upperCamelCasedParentStyle]) {\n                        that['prism' + upperCamelCasedParentStyle](token);\n                    } else if (languageDefinition[parentStyle] && languageDefinition[parentStyle].alias) {\n                        printTokens(token, languageDefinition[parentStyle].alias);\n                    } else {\n                        that.text(token);\n                    }\n                } else {\n                    printTokens(token.content, token.type);\n                }\n            }\n            printTokens(prism.tokenize(sourceText, prism.languages[language]), 'text');\n        }, true);\n    }\n};\n","module.exports={\n  \"_from\": \"magicpen-prism@^2.3.0\",\n  \"_id\": \"magicpen-prism@2.4.0\",\n  \"_inBundle\": false,\n  \"_integrity\": \"sha512-OEFZ+xksJtYgwnU5jJqDXhjvgnSFfMsSgXpJ2WWPaBJUXNKuQB0FBAiQxjRKsV5gntpg/tazH8L3apJx5eMdJg==\",\n  \"_location\": \"/magicpen-prism\",\n  \"_phantomChildren\": {},\n  \"_requested\": {\n    \"type\": \"range\",\n    \"registry\": true,\n    \"raw\": \"magicpen-prism@^2.3.0\",\n    \"name\": \"magicpen-prism\",\n    \"escapedName\": \"magicpen-prism\",\n    \"rawSpec\": \"^2.3.0\",\n    \"saveSpec\": null,\n    \"fetchSpec\": \"^2.3.0\"\n  },\n  \"_requiredBy\": [\n    \"/\"\n  ],\n  \"_resolved\": \"https://registry.npmjs.org/magicpen-prism/-/magicpen-prism-2.4.0.tgz\",\n  \"_shasum\": \"aa79ca9b656f35069ad0aea8b102f1ac8642cbb0\",\n  \"_spec\": \"magicpen-prism@^2.3.0\",\n  \"_where\": \"/Users/ssimonsen/Code/unexpected-dom\",\n  \"author\": {\n    \"name\": \"Andreas Lind\",\n    \"email\": \"andreas@one.com\"\n  },\n  \"bugs\": {\n    \"url\": \"https://github.com/unexpectedjs/magicpen-prism/issues\"\n  },\n  \"bundleDependencies\": false,\n  \"dependencies\": {\n    \"prismjs\": \"1.11.0\"\n  },\n  \"deprecated\": false,\n  \"description\": \"Add syntax highlighting support to magicpen via prism.js\",\n  \"devDependencies\": {\n    \"browserify\": \"13.0.0\",\n    \"bundle-collapser\": \"1.2.1\",\n    \"eslint\": \"2.13.1\",\n    \"eslint-config-onelint\": \"1.2.0\",\n    \"magicpen\": \"5.9.0\",\n    \"mocha\": \"2.4.5\",\n    \"unexpected\": \"10.10.5\"\n  },\n  \"files\": [\n    \"lib\",\n    \"magicPenPrism.min.js\"\n  ],\n  \"homepage\": \"https://github.com/unexpectedjs/magicpen-prism#readme\",\n  \"main\": \"lib/magicPenPrism.js\",\n  \"name\": \"magicpen-prism\",\n  \"repository\": {\n    \"type\": \"git\",\n    \"url\": \"git+https://github.com/unexpectedjs/magicpen-prism.git\"\n  },\n  \"scripts\": {\n    \"lint\": \"eslint .\",\n    \"prepublish\": \"browserify -p bundle-collapser/plugin -e lib/magicPenPrism -s magicPenPrism > magicPenPrism.min.js\",\n    \"test\": \"mocha\",\n    \"travis\": \"npm run lint && npm test\"\n  },\n  \"version\": \"2.4.0\"\n}\n","/**\n * Original by Scott Helme.\n *\n * Reference: https://scotthelme.co.uk/csp-cheat-sheet/\n *\n * Supports the following:\n *  - CSP Level 1\n *  - CSP Level 2\n *  - CSP Level 3\n */\n\nPrism.languages.csp = {\n\t'directive':  {\n             pattern: /\\b(?:(?:base-uri|form-action|frame-ancestors|plugin-types|referrer|reflected-xss|report-to|report-uri|require-sri-for|sandbox) |(?:block-all-mixed-content|disown-opener|upgrade-insecure-requests)(?: |;)|(?:child|connect|default|font|frame|img|manifest|media|object|script|style|worker)-src )/i,\n             alias: 'keyword'\n        },\n\t'safe': {\n            pattern: /'(?:self|none|strict-dynamic|(?:nonce-|sha(?:256|384|512)-)[a-zA-Z0-9+=/]+)'/,\n            alias: 'selector'\n        },\n\t'unsafe': {\n            pattern: /(?:'unsafe-inline'|'unsafe-eval'|'unsafe-hashed-attributes'|\\*)/,\n            alias: 'function'\n        }\n};","Prism.languages.graphql = {\n\t'comment': /#.*/,\n\t'string': {\n\t\tpattern: /\"(?:\\\\.|[^\\\\\"\\r\\n])*\"/,\n\t\tgreedy: true\n\t},\n\t'number': /(?:\\B-|\\b)\\d+(?:\\.\\d+)?(?:[eE][+-]?\\d+)?\\b/,\n\t'boolean': /\\b(?:true|false)\\b/,\n\t'variable': /\\$[a-z_]\\w*/i,\n\t'directive': {\n\t\tpattern: /@[a-z_]\\w*/i,\n\t\talias: 'function'\n\t},\n\t'attr-name': /[a-z_]\\w*(?=\\s*:)/i,\n\t'keyword': [\n\t\t{\n\t\t\tpattern: /(fragment\\s+(?!on)[a-z_]\\w*\\s+|\\.{3}\\s*)on\\b/,\n\t\t\tlookbehind: true\n\t\t},\n\t\t/\\b(?:query|fragment|mutation)\\b/\n\t],\n\t'operator': /!|=|\\.{3}/,\n\t'punctuation': /[!(){}\\[\\]:=,]/\n};","\n/* **********************************************\n     Begin prism-core.js\n********************************************** */\n\nvar _self = (typeof window !== 'undefined')\n\t? window   // if in browser\n\t: (\n\t\t(typeof WorkerGlobalScope !== 'undefined' && self instanceof WorkerGlobalScope)\n\t\t? self // if in worker\n\t\t: {}   // if in node js\n\t);\n\n/**\n * Prism: Lightweight, robust, elegant syntax highlighting\n * MIT license http://www.opensource.org/licenses/mit-license.php/\n * @author Lea Verou http://lea.verou.me\n */\n\nvar Prism = (function(){\n\n// Private helper vars\nvar lang = /\\blang(?:uage)?-(\\w+)\\b/i;\nvar uniqueId = 0;\n\nvar _ = _self.Prism = {\n\tmanual: _self.Prism && _self.Prism.manual,\n\tdisableWorkerMessageHandler: _self.Prism && _self.Prism.disableWorkerMessageHandler,\n\tutil: {\n\t\tencode: function (tokens) {\n\t\t\tif (tokens instanceof Token) {\n\t\t\t\treturn new Token(tokens.type, _.util.encode(tokens.content), tokens.alias);\n\t\t\t} else if (_.util.type(tokens) === 'Array') {\n\t\t\t\treturn tokens.map(_.util.encode);\n\t\t\t} else {\n\t\t\t\treturn tokens.replace(/&/g, '&amp;').replace(/</g, '&lt;').replace(/\\u00a0/g, ' ');\n\t\t\t}\n\t\t},\n\n\t\ttype: function (o) {\n\t\t\treturn Object.prototype.toString.call(o).match(/\\[object (\\w+)\\]/)[1];\n\t\t},\n\n\t\tobjId: function (obj) {\n\t\t\tif (!obj['__id']) {\n\t\t\t\tObject.defineProperty(obj, '__id', { value: ++uniqueId });\n\t\t\t}\n\t\t\treturn obj['__id'];\n\t\t},\n\n\t\t// Deep clone a language definition (e.g. to extend it)\n\t\tclone: function (o) {\n\t\t\tvar type = _.util.type(o);\n\n\t\t\tswitch (type) {\n\t\t\t\tcase 'Object':\n\t\t\t\t\tvar clone = {};\n\n\t\t\t\t\tfor (var key in o) {\n\t\t\t\t\t\tif (o.hasOwnProperty(key)) {\n\t\t\t\t\t\t\tclone[key] = _.util.clone(o[key]);\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\n\t\t\t\t\treturn clone;\n\n\t\t\t\tcase 'Array':\n\t\t\t\t\treturn o.map(function(v) { return _.util.clone(v); });\n\t\t\t}\n\n\t\t\treturn o;\n\t\t}\n\t},\n\n\tlanguages: {\n\t\textend: function (id, redef) {\n\t\t\tvar lang = _.util.clone(_.languages[id]);\n\n\t\t\tfor (var key in redef) {\n\t\t\t\tlang[key] = redef[key];\n\t\t\t}\n\n\t\t\treturn lang;\n\t\t},\n\n\t\t/**\n\t\t * Insert a token before another token in a language literal\n\t\t * As this needs to recreate the object (we cannot actually insert before keys in object literals),\n\t\t * we cannot just provide an object, we need anobject and a key.\n\t\t * @param inside The key (or language id) of the parent\n\t\t * @param before The key to insert before. If not provided, the function appends instead.\n\t\t * @param insert Object with the key/value pairs to insert\n\t\t * @param root The object that contains `inside`. If equal to Prism.languages, it can be omitted.\n\t\t */\n\t\tinsertBefore: function (inside, before, insert, root) {\n\t\t\troot = root || _.languages;\n\t\t\tvar grammar = root[inside];\n\n\t\t\tif (arguments.length == 2) {\n\t\t\t\tinsert = arguments[1];\n\n\t\t\t\tfor (var newToken in insert) {\n\t\t\t\t\tif (insert.hasOwnProperty(newToken)) {\n\t\t\t\t\t\tgrammar[newToken] = insert[newToken];\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\treturn grammar;\n\t\t\t}\n\n\t\t\tvar ret = {};\n\n\t\t\tfor (var token in grammar) {\n\n\t\t\t\tif (grammar.hasOwnProperty(token)) {\n\n\t\t\t\t\tif (token == before) {\n\n\t\t\t\t\t\tfor (var newToken in insert) {\n\n\t\t\t\t\t\t\tif (insert.hasOwnProperty(newToken)) {\n\t\t\t\t\t\t\t\tret[newToken] = insert[newToken];\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\n\t\t\t\t\tret[token] = grammar[token];\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t// Update references in other language definitions\n\t\t\t_.languages.DFS(_.languages, function(key, value) {\n\t\t\t\tif (value === root[inside] && key != inside) {\n\t\t\t\t\tthis[key] = ret;\n\t\t\t\t}\n\t\t\t});\n\n\t\t\treturn root[inside] = ret;\n\t\t},\n\n\t\t// Traverse a language definition with Depth First Search\n\t\tDFS: function(o, callback, type, visited) {\n\t\t\tvisited = visited || {};\n\t\t\tfor (var i in o) {\n\t\t\t\tif (o.hasOwnProperty(i)) {\n\t\t\t\t\tcallback.call(o, i, o[i], type || i);\n\n\t\t\t\t\tif (_.util.type(o[i]) === 'Object' && !visited[_.util.objId(o[i])]) {\n\t\t\t\t\t\tvisited[_.util.objId(o[i])] = true;\n\t\t\t\t\t\t_.languages.DFS(o[i], callback, null, visited);\n\t\t\t\t\t}\n\t\t\t\t\telse if (_.util.type(o[i]) === 'Array' && !visited[_.util.objId(o[i])]) {\n\t\t\t\t\t\tvisited[_.util.objId(o[i])] = true;\n\t\t\t\t\t\t_.languages.DFS(o[i], callback, i, visited);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t},\n\tplugins: {},\n\n\thighlightAll: function(async, callback) {\n\t\t_.highlightAllUnder(document, async, callback);\n\t},\n\n\thighlightAllUnder: function(container, async, callback) {\n\t\tvar env = {\n\t\t\tcallback: callback,\n\t\t\tselector: 'code[class*=\"language-\"], [class*=\"language-\"] code, code[class*=\"lang-\"], [class*=\"lang-\"] code'\n\t\t};\n\n\t\t_.hooks.run(\"before-highlightall\", env);\n\n\t\tvar elements = env.elements || container.querySelectorAll(env.selector);\n\n\t\tfor (var i=0, element; element = elements[i++];) {\n\t\t\t_.highlightElement(element, async === true, env.callback);\n\t\t}\n\t},\n\n\thighlightElement: function(element, async, callback) {\n\t\t// Find language\n\t\tvar language, grammar, parent = element;\n\n\t\twhile (parent && !lang.test(parent.className)) {\n\t\t\tparent = parent.parentNode;\n\t\t}\n\n\t\tif (parent) {\n\t\t\tlanguage = (parent.className.match(lang) || [,''])[1].toLowerCase();\n\t\t\tgrammar = _.languages[language];\n\t\t}\n\n\t\t// Set language on the element, if not present\n\t\telement.className = element.className.replace(lang, '').replace(/\\s+/g, ' ') + ' language-' + language;\n\n\t\tif (element.parentNode) {\n\t\t\t// Set language on the parent, for styling\n\t\t\tparent = element.parentNode;\n\n\t\t\tif (/pre/i.test(parent.nodeName)) {\n\t\t\t\tparent.className = parent.className.replace(lang, '').replace(/\\s+/g, ' ') + ' language-' + language;\n\t\t\t}\n\t\t}\n\n\t\tvar code = element.textContent;\n\n\t\tvar env = {\n\t\t\telement: element,\n\t\t\tlanguage: language,\n\t\t\tgrammar: grammar,\n\t\t\tcode: code\n\t\t};\n\n\t\t_.hooks.run('before-sanity-check', env);\n\n\t\tif (!env.code || !env.grammar) {\n\t\t\tif (env.code) {\n\t\t\t\t_.hooks.run('before-highlight', env);\n\t\t\t\tenv.element.textContent = env.code;\n\t\t\t\t_.hooks.run('after-highlight', env);\n\t\t\t}\n\t\t\t_.hooks.run('complete', env);\n\t\t\treturn;\n\t\t}\n\n\t\t_.hooks.run('before-highlight', env);\n\n\t\tif (async && _self.Worker) {\n\t\t\tvar worker = new Worker(_.filename);\n\n\t\t\tworker.onmessage = function(evt) {\n\t\t\t\tenv.highlightedCode = evt.data;\n\n\t\t\t\t_.hooks.run('before-insert', env);\n\n\t\t\t\tenv.element.innerHTML = env.highlightedCode;\n\n\t\t\t\tcallback && callback.call(env.element);\n\t\t\t\t_.hooks.run('after-highlight', env);\n\t\t\t\t_.hooks.run('complete', env);\n\t\t\t};\n\n\t\t\tworker.postMessage(JSON.stringify({\n\t\t\t\tlanguage: env.language,\n\t\t\t\tcode: env.code,\n\t\t\t\timmediateClose: true\n\t\t\t}));\n\t\t}\n\t\telse {\n\t\t\tenv.highlightedCode = _.highlight(env.code, env.grammar, env.language);\n\n\t\t\t_.hooks.run('before-insert', env);\n\n\t\t\tenv.element.innerHTML = env.highlightedCode;\n\n\t\t\tcallback && callback.call(element);\n\n\t\t\t_.hooks.run('after-highlight', env);\n\t\t\t_.hooks.run('complete', env);\n\t\t}\n\t},\n\n\thighlight: function (text, grammar, language) {\n\t\tvar tokens = _.tokenize(text, grammar);\n\t\treturn Token.stringify(_.util.encode(tokens), language);\n\t},\n\n\tmatchGrammar: function (text, strarr, grammar, index, startPos, oneshot, target) {\n\t\tvar Token = _.Token;\n\n\t\tfor (var token in grammar) {\n\t\t\tif(!grammar.hasOwnProperty(token) || !grammar[token]) {\n\t\t\t\tcontinue;\n\t\t\t}\n\n\t\t\tif (token == target) {\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\tvar patterns = grammar[token];\n\t\t\tpatterns = (_.util.type(patterns) === \"Array\") ? patterns : [patterns];\n\n\t\t\tfor (var j = 0; j < patterns.length; ++j) {\n\t\t\t\tvar pattern = patterns[j],\n\t\t\t\t\tinside = pattern.inside,\n\t\t\t\t\tlookbehind = !!pattern.lookbehind,\n\t\t\t\t\tgreedy = !!pattern.greedy,\n\t\t\t\t\tlookbehindLength = 0,\n\t\t\t\t\talias = pattern.alias;\n\n\t\t\t\tif (greedy && !pattern.pattern.global) {\n\t\t\t\t\t// Without the global flag, lastIndex won't work\n\t\t\t\t\tvar flags = pattern.pattern.toString().match(/[imuy]*$/)[0];\n\t\t\t\t\tpattern.pattern = RegExp(pattern.pattern.source, flags + \"g\");\n\t\t\t\t}\n\n\t\t\t\tpattern = pattern.pattern || pattern;\n\n\t\t\t\t// Don’t cache length as it changes during the loop\n\t\t\t\tfor (var i = index, pos = startPos; i < strarr.length; pos += strarr[i].length, ++i) {\n\n\t\t\t\t\tvar str = strarr[i];\n\n\t\t\t\t\tif (strarr.length > text.length) {\n\t\t\t\t\t\t// Something went terribly wrong, ABORT, ABORT!\n\t\t\t\t\t\treturn;\n\t\t\t\t\t}\n\n\t\t\t\t\tif (str instanceof Token) {\n\t\t\t\t\t\tcontinue;\n\t\t\t\t\t}\n\n\t\t\t\t\tpattern.lastIndex = 0;\n\n\t\t\t\t\tvar match = pattern.exec(str),\n\t\t\t\t\t    delNum = 1;\n\n\t\t\t\t\t// Greedy patterns can override/remove up to two previously matched tokens\n\t\t\t\t\tif (!match && greedy && i != strarr.length - 1) {\n\t\t\t\t\t\tpattern.lastIndex = pos;\n\t\t\t\t\t\tmatch = pattern.exec(text);\n\t\t\t\t\t\tif (!match) {\n\t\t\t\t\t\t\tbreak;\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\tvar from = match.index + (lookbehind ? match[1].length : 0),\n\t\t\t\t\t\t    to = match.index + match[0].length,\n\t\t\t\t\t\t    k = i,\n\t\t\t\t\t\t    p = pos;\n\n\t\t\t\t\t\tfor (var len = strarr.length; k < len && (p < to || (!strarr[k].type && !strarr[k - 1].greedy)); ++k) {\n\t\t\t\t\t\t\tp += strarr[k].length;\n\t\t\t\t\t\t\t// Move the index i to the element in strarr that is closest to from\n\t\t\t\t\t\t\tif (from >= p) {\n\t\t\t\t\t\t\t\t++i;\n\t\t\t\t\t\t\t\tpos = p;\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\t/*\n\t\t\t\t\t\t * If strarr[i] is a Token, then the match starts inside another Token, which is invalid\n\t\t\t\t\t\t * If strarr[k - 1] is greedy we are in conflict with another greedy pattern\n\t\t\t\t\t\t */\n\t\t\t\t\t\tif (strarr[i] instanceof Token || strarr[k - 1].greedy) {\n\t\t\t\t\t\t\tcontinue;\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\t// Number of tokens to delete and replace with the new match\n\t\t\t\t\t\tdelNum = k - i;\n\t\t\t\t\t\tstr = text.slice(pos, p);\n\t\t\t\t\t\tmatch.index -= pos;\n\t\t\t\t\t}\n\n\t\t\t\t\tif (!match) {\n\t\t\t\t\t\tif (oneshot) {\n\t\t\t\t\t\t\tbreak;\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\tcontinue;\n\t\t\t\t\t}\n\n\t\t\t\t\tif(lookbehind) {\n\t\t\t\t\t\tlookbehindLength = match[1].length;\n\t\t\t\t\t}\n\n\t\t\t\t\tvar from = match.index + lookbehindLength,\n\t\t\t\t\t    match = match[0].slice(lookbehindLength),\n\t\t\t\t\t    to = from + match.length,\n\t\t\t\t\t    before = str.slice(0, from),\n\t\t\t\t\t    after = str.slice(to);\n\n\t\t\t\t\tvar args = [i, delNum];\n\n\t\t\t\t\tif (before) {\n\t\t\t\t\t\t++i;\n\t\t\t\t\t\tpos += before.length;\n\t\t\t\t\t\targs.push(before);\n\t\t\t\t\t}\n\n\t\t\t\t\tvar wrapped = new Token(token, inside? _.tokenize(match, inside) : match, alias, match, greedy);\n\n\t\t\t\t\targs.push(wrapped);\n\n\t\t\t\t\tif (after) {\n\t\t\t\t\t\targs.push(after);\n\t\t\t\t\t}\n\n\t\t\t\t\tArray.prototype.splice.apply(strarr, args);\n\n\t\t\t\t\tif (delNum != 1)\n\t\t\t\t\t\t_.matchGrammar(text, strarr, grammar, i, pos, true, token);\n\n\t\t\t\t\tif (oneshot)\n\t\t\t\t\t\tbreak;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t},\n\n\ttokenize: function(text, grammar, language) {\n\t\tvar strarr = [text];\n\n\t\tvar rest = grammar.rest;\n\n\t\tif (rest) {\n\t\t\tfor (var token in rest) {\n\t\t\t\tgrammar[token] = rest[token];\n\t\t\t}\n\n\t\t\tdelete grammar.rest;\n\t\t}\n\n\t\t_.matchGrammar(text, strarr, grammar, 0, 0, false);\n\n\t\treturn strarr;\n\t},\n\n\thooks: {\n\t\tall: {},\n\n\t\tadd: function (name, callback) {\n\t\t\tvar hooks = _.hooks.all;\n\n\t\t\thooks[name] = hooks[name] || [];\n\n\t\t\thooks[name].push(callback);\n\t\t},\n\n\t\trun: function (name, env) {\n\t\t\tvar callbacks = _.hooks.all[name];\n\n\t\t\tif (!callbacks || !callbacks.length) {\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\tfor (var i=0, callback; callback = callbacks[i++];) {\n\t\t\t\tcallback(env);\n\t\t\t}\n\t\t}\n\t}\n};\n\nvar Token = _.Token = function(type, content, alias, matchedStr, greedy) {\n\tthis.type = type;\n\tthis.content = content;\n\tthis.alias = alias;\n\t// Copy of the full string this token was created from\n\tthis.length = (matchedStr || \"\").length|0;\n\tthis.greedy = !!greedy;\n};\n\nToken.stringify = function(o, language, parent) {\n\tif (typeof o == 'string') {\n\t\treturn o;\n\t}\n\n\tif (_.util.type(o) === 'Array') {\n\t\treturn o.map(function(element) {\n\t\t\treturn Token.stringify(element, language, o);\n\t\t}).join('');\n\t}\n\n\tvar env = {\n\t\ttype: o.type,\n\t\tcontent: Token.stringify(o.content, language, parent),\n\t\ttag: 'span',\n\t\tclasses: ['token', o.type],\n\t\tattributes: {},\n\t\tlanguage: language,\n\t\tparent: parent\n\t};\n\n\tif (o.alias) {\n\t\tvar aliases = _.util.type(o.alias) === 'Array' ? o.alias : [o.alias];\n\t\tArray.prototype.push.apply(env.classes, aliases);\n\t}\n\n\t_.hooks.run('wrap', env);\n\n\tvar attributes = Object.keys(env.attributes).map(function(name) {\n\t\treturn name + '=\"' + (env.attributes[name] || '').replace(/\"/g, '&quot;') + '\"';\n\t}).join(' ');\n\n\treturn '<' + env.tag + ' class=\"' + env.classes.join(' ') + '\"' + (attributes ? ' ' + attributes : '') + '>' + env.content + '</' + env.tag + '>';\n\n};\n\nif (!_self.document) {\n\tif (!_self.addEventListener) {\n\t\t// in Node.js\n\t\treturn _self.Prism;\n\t}\n\n\tif (!_.disableWorkerMessageHandler) {\n\t\t// In worker\n\t\t_self.addEventListener('message', function (evt) {\n\t\t\tvar message = JSON.parse(evt.data),\n\t\t\t\tlang = message.language,\n\t\t\t\tcode = message.code,\n\t\t\t\timmediateClose = message.immediateClose;\n\n\t\t\t_self.postMessage(_.highlight(code, _.languages[lang], lang));\n\t\t\tif (immediateClose) {\n\t\t\t\t_self.close();\n\t\t\t}\n\t\t}, false);\n\t}\n\n\treturn _self.Prism;\n}\n\n//Get current script and highlight\nvar script = document.currentScript || [].slice.call(document.getElementsByTagName(\"script\")).pop();\n\nif (script) {\n\t_.filename = script.src;\n\n\tif (!_.manual && !script.hasAttribute('data-manual')) {\n\t\tif(document.readyState !== \"loading\") {\n\t\t\tif (window.requestAnimationFrame) {\n\t\t\t\twindow.requestAnimationFrame(_.highlightAll);\n\t\t\t} else {\n\t\t\t\twindow.setTimeout(_.highlightAll, 16);\n\t\t\t}\n\t\t}\n\t\telse {\n\t\t\tdocument.addEventListener('DOMContentLoaded', _.highlightAll);\n\t\t}\n\t}\n}\n\nreturn _self.Prism;\n\n})();\n\nif (typeof module !== 'undefined' && module.exports) {\n\tmodule.exports = Prism;\n}\n\n// hack for components to work correctly in node.js\nif (typeof global !== 'undefined') {\n\tglobal.Prism = Prism;\n}\n\n\n/* **********************************************\n     Begin prism-markup.js\n********************************************** */\n\nPrism.languages.markup = {\n\t'comment': /<!--[\\s\\S]*?-->/,\n\t'prolog': /<\\?[\\s\\S]+?\\?>/,\n\t'doctype': /<!DOCTYPE[\\s\\S]+?>/i,\n\t'cdata': /<!\\[CDATA\\[[\\s\\S]*?]]>/i,\n\t'tag': {\n\t\tpattern: /<\\/?(?!\\d)[^\\s>\\/=$<]+(?:\\s+[^\\s>\\/=]+(?:=(?:(\"|')(?:\\\\[\\s\\S]|(?!\\1)[^\\\\])*\\1|[^\\s'\">=]+))?)*\\s*\\/?>/i,\n\t\tinside: {\n\t\t\t'tag': {\n\t\t\t\tpattern: /^<\\/?[^\\s>\\/]+/i,\n\t\t\t\tinside: {\n\t\t\t\t\t'punctuation': /^<\\/?/,\n\t\t\t\t\t'namespace': /^[^\\s>\\/:]+:/\n\t\t\t\t}\n\t\t\t},\n\t\t\t'attr-value': {\n\t\t\t\tpattern: /=(?:(\"|')(?:\\\\[\\s\\S]|(?!\\1)[^\\\\])*\\1|[^\\s'\">=]+)/i,\n\t\t\t\tinside: {\n\t\t\t\t\t'punctuation': [\n\t\t\t\t\t\t/^=/,\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tpattern: /(^|[^\\\\])[\"']/,\n\t\t\t\t\t\t\tlookbehind: true\n\t\t\t\t\t\t}\n\t\t\t\t\t]\n\t\t\t\t}\n\t\t\t},\n\t\t\t'punctuation': /\\/?>/,\n\t\t\t'attr-name': {\n\t\t\t\tpattern: /[^\\s>\\/]+/,\n\t\t\t\tinside: {\n\t\t\t\t\t'namespace': /^[^\\s>\\/:]+:/\n\t\t\t\t}\n\t\t\t}\n\n\t\t}\n\t},\n\t'entity': /&#?[\\da-z]{1,8};/i\n};\n\nPrism.languages.markup['tag'].inside['attr-value'].inside['entity'] =\n\tPrism.languages.markup['entity'];\n\n// Plugin to make entity title show the real entity, idea by Roman Komarov\nPrism.hooks.add('wrap', function(env) {\n\n\tif (env.type === 'entity') {\n\t\tenv.attributes['title'] = env.content.replace(/&amp;/, '&');\n\t}\n});\n\nPrism.languages.xml = Prism.languages.markup;\nPrism.languages.html = Prism.languages.markup;\nPrism.languages.mathml = Prism.languages.markup;\nPrism.languages.svg = Prism.languages.markup;\n\n\n/* **********************************************\n     Begin prism-css.js\n********************************************** */\n\nPrism.languages.css = {\n\t'comment': /\\/\\*[\\s\\S]*?\\*\\//,\n\t'atrule': {\n\t\tpattern: /@[\\w-]+?.*?(?:;|(?=\\s*\\{))/i,\n\t\tinside: {\n\t\t\t'rule': /@[\\w-]+/\n\t\t\t// See rest below\n\t\t}\n\t},\n\t'url': /url\\((?:([\"'])(?:\\\\(?:\\r\\n|[\\s\\S])|(?!\\1)[^\\\\\\r\\n])*\\1|.*?)\\)/i,\n\t'selector': /[^{}\\s][^{};]*?(?=\\s*\\{)/,\n\t'string': {\n\t\tpattern: /(\"|')(?:\\\\(?:\\r\\n|[\\s\\S])|(?!\\1)[^\\\\\\r\\n])*\\1/,\n\t\tgreedy: true\n\t},\n\t'property': /[-_a-z\\xA0-\\uFFFF][-\\w\\xA0-\\uFFFF]*(?=\\s*:)/i,\n\t'important': /\\B!important\\b/i,\n\t'function': /[-a-z0-9]+(?=\\()/i,\n\t'punctuation': /[(){};:]/\n};\n\nPrism.languages.css['atrule'].inside.rest = Prism.util.clone(Prism.languages.css);\n\nif (Prism.languages.markup) {\n\tPrism.languages.insertBefore('markup', 'tag', {\n\t\t'style': {\n\t\t\tpattern: /(<style[\\s\\S]*?>)[\\s\\S]*?(?=<\\/style>)/i,\n\t\t\tlookbehind: true,\n\t\t\tinside: Prism.languages.css,\n\t\t\talias: 'language-css',\n\t\t\tgreedy: true\n\t\t}\n\t});\n\n\tPrism.languages.insertBefore('inside', 'attr-value', {\n\t\t'style-attr': {\n\t\t\tpattern: /\\s*style=(\"|')(?:\\\\[\\s\\S]|(?!\\1)[^\\\\])*\\1/i,\n\t\t\tinside: {\n\t\t\t\t'attr-name': {\n\t\t\t\t\tpattern: /^\\s*style/i,\n\t\t\t\t\tinside: Prism.languages.markup.tag.inside\n\t\t\t\t},\n\t\t\t\t'punctuation': /^\\s*=\\s*['\"]|['\"]\\s*$/,\n\t\t\t\t'attr-value': {\n\t\t\t\t\tpattern: /.+/i,\n\t\t\t\t\tinside: Prism.languages.css\n\t\t\t\t}\n\t\t\t},\n\t\t\talias: 'language-css'\n\t\t}\n\t}, Prism.languages.markup.tag);\n}\n\n/* **********************************************\n     Begin prism-clike.js\n********************************************** */\n\nPrism.languages.clike = {\n\t'comment': [\n\t\t{\n\t\t\tpattern: /(^|[^\\\\])\\/\\*[\\s\\S]*?(?:\\*\\/|$)/,\n\t\t\tlookbehind: true\n\t\t},\n\t\t{\n\t\t\tpattern: /(^|[^\\\\:])\\/\\/.*/,\n\t\t\tlookbehind: true\n\t\t}\n\t],\n\t'string': {\n\t\tpattern: /([\"'])(?:\\\\(?:\\r\\n|[\\s\\S])|(?!\\1)[^\\\\\\r\\n])*\\1/,\n\t\tgreedy: true\n\t},\n\t'class-name': {\n\t\tpattern: /((?:\\b(?:class|interface|extends|implements|trait|instanceof|new)\\s+)|(?:catch\\s+\\())[\\w.\\\\]+/i,\n\t\tlookbehind: true,\n\t\tinside: {\n\t\t\tpunctuation: /[.\\\\]/\n\t\t}\n\t},\n\t'keyword': /\\b(?:if|else|while|do|for|return|in|instanceof|function|new|try|throw|catch|finally|null|break|continue)\\b/,\n\t'boolean': /\\b(?:true|false)\\b/,\n\t'function': /[a-z0-9_]+(?=\\()/i,\n\t'number': /\\b-?(?:0x[\\da-f]+|\\d*\\.?\\d+(?:e[+-]?\\d+)?)\\b/i,\n\t'operator': /--?|\\+\\+?|!=?=?|<=?|>=?|==?=?|&&?|\\|\\|?|\\?|\\*|\\/|~|\\^|%/,\n\t'punctuation': /[{}[\\];(),.:]/\n};\n\n\n/* **********************************************\n     Begin prism-javascript.js\n********************************************** */\n\nPrism.languages.javascript = Prism.languages.extend('clike', {\n\t'keyword': /\\b(?:as|async|await|break|case|catch|class|const|continue|debugger|default|delete|do|else|enum|export|extends|finally|for|from|function|get|if|implements|import|in|instanceof|interface|let|new|null|of|package|private|protected|public|return|set|static|super|switch|this|throw|try|typeof|var|void|while|with|yield)\\b/,\n\t'number': /\\b-?(?:0[xX][\\dA-Fa-f]+|0[bB][01]+|0[oO][0-7]+|\\d*\\.?\\d+(?:[Ee][+-]?\\d+)?|NaN|Infinity)\\b/,\n\t// Allow for all non-ASCII characters (See http://stackoverflow.com/a/2008444)\n\t'function': /[_$a-z\\xA0-\\uFFFF][$\\w\\xA0-\\uFFFF]*(?=\\s*\\()/i,\n\t'operator': /-[-=]?|\\+[+=]?|!=?=?|<<?=?|>>?>?=?|=(?:==?|>)?|&[&=]?|\\|[|=]?|\\*\\*?=?|\\/=?|~|\\^=?|%=?|\\?|\\.{3}/\n});\n\nPrism.languages.insertBefore('javascript', 'keyword', {\n\t'regex': {\n\t\tpattern: /(^|[^/])\\/(?!\\/)(\\[[^\\]\\r\\n]+]|\\\\.|[^/\\\\\\[\\r\\n])+\\/[gimyu]{0,5}(?=\\s*($|[\\r\\n,.;})]))/,\n\t\tlookbehind: true,\n\t\tgreedy: true\n\t},\n\t// This must be declared before keyword because we use \"function\" inside the look-forward\n\t'function-variable': {\n\t\tpattern: /[_$a-z\\xA0-\\uFFFF][$\\w\\xA0-\\uFFFF]*(?=\\s*=\\s*(?:function\\b|(?:\\([^()]*\\)|[_$a-z\\xA0-\\uFFFF][$\\w\\xA0-\\uFFFF]*)\\s*=>))/i,\n\t\talias: 'function'\n\t}\n});\n\nPrism.languages.insertBefore('javascript', 'string', {\n\t'template-string': {\n\t\tpattern: /`(?:\\\\[\\s\\S]|[^\\\\`])*`/,\n\t\tgreedy: true,\n\t\tinside: {\n\t\t\t'interpolation': {\n\t\t\t\tpattern: /\\$\\{[^}]+\\}/,\n\t\t\t\tinside: {\n\t\t\t\t\t'interpolation-punctuation': {\n\t\t\t\t\t\tpattern: /^\\$\\{|\\}$/,\n\t\t\t\t\t\talias: 'punctuation'\n\t\t\t\t\t},\n\t\t\t\t\trest: Prism.languages.javascript\n\t\t\t\t}\n\t\t\t},\n\t\t\t'string': /[\\s\\S]+/\n\t\t}\n\t}\n});\n\nif (Prism.languages.markup) {\n\tPrism.languages.insertBefore('markup', 'tag', {\n\t\t'script': {\n\t\t\tpattern: /(<script[\\s\\S]*?>)[\\s\\S]*?(?=<\\/script>)/i,\n\t\t\tlookbehind: true,\n\t\t\tinside: Prism.languages.javascript,\n\t\t\talias: 'language-javascript',\n\t\t\tgreedy: true\n\t\t}\n\t});\n}\n\nPrism.languages.js = Prism.languages.javascript;\n\n\n/* **********************************************\n     Begin prism-file-highlight.js\n********************************************** */\n\n(function () {\n\tif (typeof self === 'undefined' || !self.Prism || !self.document || !document.querySelector) {\n\t\treturn;\n\t}\n\n\tself.Prism.fileHighlight = function() {\n\n\t\tvar Extensions = {\n\t\t\t'js': 'javascript',\n\t\t\t'py': 'python',\n\t\t\t'rb': 'ruby',\n\t\t\t'ps1': 'powershell',\n\t\t\t'psm1': 'powershell',\n\t\t\t'sh': 'bash',\n\t\t\t'bat': 'batch',\n\t\t\t'h': 'c',\n\t\t\t'tex': 'latex'\n\t\t};\n\n\t\tArray.prototype.slice.call(document.querySelectorAll('pre[data-src]')).forEach(function (pre) {\n\t\t\tvar src = pre.getAttribute('data-src');\n\n\t\t\tvar language, parent = pre;\n\t\t\tvar lang = /\\blang(?:uage)?-(?!\\*)(\\w+)\\b/i;\n\t\t\twhile (parent && !lang.test(parent.className)) {\n\t\t\t\tparent = parent.parentNode;\n\t\t\t}\n\n\t\t\tif (parent) {\n\t\t\t\tlanguage = (pre.className.match(lang) || [, ''])[1];\n\t\t\t}\n\n\t\t\tif (!language) {\n\t\t\t\tvar extension = (src.match(/\\.(\\w+)$/) || [, ''])[1];\n\t\t\t\tlanguage = Extensions[extension] || extension;\n\t\t\t}\n\n\t\t\tvar code = document.createElement('code');\n\t\t\tcode.className = 'language-' + language;\n\n\t\t\tpre.textContent = '';\n\n\t\t\tcode.textContent = 'Loading…';\n\n\t\t\tpre.appendChild(code);\n\n\t\t\tvar xhr = new XMLHttpRequest();\n\n\t\t\txhr.open('GET', src, true);\n\n\t\t\txhr.onreadystatechange = function () {\n\t\t\t\tif (xhr.readyState == 4) {\n\n\t\t\t\t\tif (xhr.status < 400 && xhr.responseText) {\n\t\t\t\t\t\tcode.textContent = xhr.responseText;\n\n\t\t\t\t\t\tPrism.highlightElement(code);\n\t\t\t\t\t}\n\t\t\t\t\telse if (xhr.status >= 400) {\n\t\t\t\t\t\tcode.textContent = '✖ Error ' + xhr.status + ' while fetching file: ' + xhr.statusText;\n\t\t\t\t\t}\n\t\t\t\t\telse {\n\t\t\t\t\t\tcode.textContent = '✖ Error: File does not exist or is empty';\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t};\n\n\t\t\txhr.send(null);\n\t\t});\n\n\t};\n\n\tdocument.addEventListener('DOMContentLoaded', self.Prism.fileHighlight);\n\n})();\n"]} diff --git a/unexpected-dom.min.js b/unexpected-dom.min.js index 6725da24..f9259804 100644 --- a/unexpected-dom.min.js +++ b/unexpected-dom.min.js @@ -1,2 +1,2 @@ -(function(f){if(typeof exports==="object"&&typeof module!=="undefined"){module.exports=f()}else if(typeof define==="function"&&define.amd){define([],f)}else{var g;if(typeof window!=="undefined"){g=window}else if(typeof global!=="undefined"){g=global}else if(typeof self!=="undefined"){g=self}else{g=this}(g.unexpected||(g.unexpected={})).dom=f()}})(function(){var define,module,exports;return function(){function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require=="function"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error("Cannot find module '"+o+"'");throw f.code="MODULE_NOT_FOUND",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require=="function"&&require;for(var o=0;o"}var htmlDocument;if(typeof DOMParser!=="undefined"){htmlDocument=(new DOMParser).parseFromString(str,"text/html")}else if(typeof document!=="undefined"&&document.implementation&&document.implementation.createHTMLDocument){htmlDocument=document.implementation.createHTMLDocument("");htmlDocument.open();htmlDocument.write(str);htmlDocument.close()}else{var jsdom;try{jsdom=require(""+"jsdom")}catch(err){throw new Error("unexpected-dom"+(assertionNameForErrorMessage?" ("+assertionNameForErrorMessage+")":"")+": Running outside a browser, but could not find the `jsdom` module. Please npm install jsdom to make this work.")}if(jsdom.JSDOM){htmlDocument=new jsdom.JSDOM(str).window.document}else{htmlDocument=jsdom.jsdom(str)}}if(isFragment){var body=htmlDocument.body;var documentFragment=htmlDocument.createDocumentFragment();if(body){for(var i=0;i"}}module.exports={name:"unexpected-dom",installInto:function(expect){expect=expect.child();expect.use(require("magicpen-prism"));var topLevelExpect=expect;expect.exportType({name:"DOMNode",base:"object",identify:function(obj){return obj&&obj.nodeName&&[2,3,4,5,6,7,10,11,12].indexOf(obj.nodeType)>-1},equal:function(a,b){return a.nodeValue===b.nodeValue},inspect:function(element,depth,output){return output.code(element.nodeName+' "'+element.nodeValue+'"',"prism-string")}});expect.exportType({name:"DOMComment",base:"DOMNode",identify:function(obj){return obj&&typeof obj.nodeType==="number"&&obj.nodeType===8},equal:function(a,b){return a.nodeValue===b.nodeValue},inspect:function(element,depth,output){return output.code("\x3c!--"+element.nodeValue+"--\x3e","html")},diff:function(actual,expected,output,diff,inspect,equal){var d=diff("\x3c!--"+actual.nodeValue+"--\x3e","\x3c!--"+expected.nodeValue+"--\x3e");d.inline=true;return d}});expect.exportType({name:"DOMTextNode",base:"DOMNode",identify:function(obj){return obj&&typeof obj.nodeType==="number"&&obj.nodeType===3},equal:function(a,b){return a.nodeValue===b.nodeValue},inspect:function(element,depth,output){return output.code(entitify(element.nodeValue.trim()),"html")},diff:function(actual,expected,output,diff,inspect,equal){var d=diff(actual.nodeValue,expected.nodeValue);d.inline=true;return d}});expect.exportType({name:"DOMNodeList",base:"array-like",prefix:function(output){return output.text("NodeList[")},suffix:function(output){return output.text("]")},similar:function(a,b){return a.nodeType===1&&b.nodeType===1&&a.nodeName===b.nodeName},identify:function(obj){return obj&&typeof obj.length==="number"&&typeof obj.toString==="function"&&typeof obj.item==="function"&&(obj.toString().indexOf("NodeList")!==-1||obj.constructor&&obj.constructor.name==="NodeList")}});expect.exportType({name:"attachedDOMNodeList",base:"DOMNodeList",indent:false,prefix:function(output){return output},suffix:function(output){return output},delimiter:function(output){return output},identify:function(obj){return obj&&obj._isAttachedDOMNodeList}});function makeAttachedDOMNodeList(domNodeList,contentType){var attachedDOMNodeList=[];for(var i=0;i","html")},equal:function(a,b){return a.toString()===b.toString()},diff:function(actual,expected,output,diff){var d=diff("","");d.inline=true;return d}});expect.exportType({name:"DOMDocument",base:"DOMNode",identify:function(obj){return obj&&typeof obj.nodeType==="number"&&obj.nodeType===9&&obj.documentElement&&obj.implementation},inspect:function(document,depth,output,inspect){for(var i=0;i',"xml");for(var i=0;i0){if(depth===1){output.text("...")}else{var inspectedChildren=[];if(elementName==="script"){var type=element.getAttribute("type");if(!type||/javascript/.test(type)){type="javascript"}inspectedChildren.push(output.clone().code(element.textContent,type))}else if(elementName==="style"){inspectedChildren.push(output.clone().code(element.textContent,element.getAttribute("type")||"text/css"))}else{for(var i=0;i60||o.height>1});if(multipleLines){output.nl().indentLines();inspectedChildren.forEach(function(inspectedChild,index){output.i().block(inspectedChild).nl()});output.outdentLines()}else{inspectedChildren.forEach(function(inspectedChild,index){output.append(inspectedChild)})}}}output.code(stringifyEndTag(element),"html");return output},diffLimit:512,diff:function(actual,expected,output,diff,inspect,equal){var isHtml=isInsideHtmlDocument(actual);output.inline=true;if(Math.max(actual.length,expected.length)>this.diffLimit){output.jsComment("Diff suppressed due to size > "+this.diffLimit);return output}var emptyElements=actual.childNodes.length===0&&expected.childNodes.length===0;var conflictingElement=actual.nodeName.toLowerCase()!==expected.nodeName.toLowerCase()||!equal(getAttributes(actual),getAttributes(expected));if(conflictingElement){var canContinueLine=true;output.prismPunctuation("<").prismTag(actual.nodeName.toLowerCase());if(actual.nodeName.toLowerCase()!==expected.nodeName.toLowerCase()){output.sp().annotationBlock(function(){this.error("should be").sp().prismTag(expected.nodeName.toLowerCase())}).nl();canContinueLine=false}var actualAttributes=getAttributes(actual);var expectedAttributes=getAttributes(expected);Object.keys(actualAttributes).forEach(function(attributeName){output.sp(canContinueLine?1:2+actual.nodeName.length);writeAttributeToMagicPen(output,attributeName,actualAttributes[attributeName],isHtml);if(attributeName in expectedAttributes){if(actualAttributes[attributeName]===expectedAttributes[attributeName]){canContinueLine=true}else{output.sp().annotationBlock(function(){this.error("should equal").sp().append(inspect(entitify(expectedAttributes[attributeName])))}).nl();canContinueLine=false}delete expectedAttributes[attributeName]}else{output.sp().annotationBlock(function(){this.error("should be removed")}).nl();canContinueLine=false}});Object.keys(expectedAttributes).forEach(function(attributeName){output.sp(canContinueLine?1:2+actual.nodeName.length);output.annotationBlock(function(){this.error("missing").sp();writeAttributeToMagicPen(this,attributeName,expectedAttributes[attributeName],isHtml)}).nl();canContinueLine=false});output.prismPunctuation(">")}else{output.code(stringifyStartTag(actual),"html")}if(!emptyElements){output.nl().indentLines().i().block(diff(makeAttachedDOMNodeList(actual.childNodes),makeAttachedDOMNodeList(expected.childNodes)).diff).nl().outdentLines()}output.code(stringifyEndTag(actual),"html");return output}});expect.exportAssertion(" to have (class|classes) ",function(expect,subject,value){return expect(subject,"to have attributes",{class:value})});expect.exportAssertion(" to only have (class|classes) ",function(expect,subject,value){return expect(subject,"to have attributes",{class:function(className){var actualClasses=getClassNamesFromAttributeValue(className);if(typeof value==="string"){value=getClassNamesFromAttributeValue(value)}return topLevelExpect(actualClasses.sort(),"to equal",value.sort())}})});expect.exportAssertion(" to [exhaustively] satisfy ",function(expect,subject,value){return expect(subject.nodeValue,"to equal",value.nodeValue)});expect.exportAssertion(" to [exhaustively] satisfy ",function(expect,subject,value){expect.fail()});expect.exportAssertion(" to [exhaustively] satisfy ",function(expect,subject,value){return expect(subject.nodeValue,"to satisfy",value)});expect.exportAssertion(" to [exhaustively] satisfy ",function(expect,subject,value){return expect(subject.nodeValue,"to satisfy",value)});function convertDOMNodeToSatisfySpec(node,isHtml){if(node.nodeType===8&&node.nodeValue.trim()==="ignore"){return{}}else if(node.nodeType===10){return{name:node.nodeName}}else if(node.nodeType===1){var result={name:isHtml?node.nodeName.toLowerCase():node.nodeName};if(node.attributes){result.attributes={};for(var i=0;i to [exhaustively] satisfy ",function(expect,subject,value){var isHtml=subject.ownerDocument.contentType==="text/html";expect.argsOutput=function(output){return output.code(value,isHtml?"html":"xml")};return expect(subject,"to [exhaustively] satisfy",(isHtml?parseHtml(value,true,expect.testDescription):parseXml(value,expect.testDescription)).childNodes)});expect.exportAssertion(" to [exhaustively] satisfy ",function(expect,subject,value){var isHtml=subject.ownerDocument.contentType==="text/html";var satisfySpecs=[];for(var i=0;i to [exhaustively] satisfy ",function(expect,subject,value){var isHtml=isInsideHtmlDocument(subject);expect.argsOutput=function(output){return output.code(value,isHtml?"html":"xml")};return expect(subject,"to [exhaustively] satisfy",isHtml?parseHtml(value,true,expect.testDescription):parseXml(value,expect.testDescription))});expect.exportAssertion(" to [exhaustively] satisfy ",function(expect,subject,value){var isHtml=subject.ownerDocument.contentType==="text/html";return expect(subject,"to [exhaustively] satisfy",Array.prototype.map.call(value.childNodes,function(childNode){return convertDOMNodeToSatisfySpec(childNode,isHtml)}))});expect.exportAssertion(" to [exhaustively] satisfy ",function(expect,subject,value){return expect(subject.childNodes,"to [exhaustively] satisfy",value)});expect.exportAssertion(" to [exhaustively] satisfy ",function(expect,subject,value){var isHtml=isInsideHtmlDocument(subject);var documentFragment=isHtml?parseHtml(value,true,this.testDescription):parseXml(value,this.testDescription);if(documentFragment.childNodes.length!==1){throw new Error("HTMLElement to satisfy string: Only a single node is supported")}expect.argsOutput=function(output){return output.code(value,isHtml?"html":"xml")};return expect(subject,"to [exhaustively] satisfy",documentFragment.childNodes[0])});expect.exportAssertion(" to [exhaustively] satisfy ",function(expect,subject,value){var isHtml=isInsideHtmlDocument(subject);var valueDocument=isHtml?parseHtml(value,false,this.testDescription):parseXml(value,this.testDescription);return expect(makeAttachedDOMNodeList(subject.childNodes),"to [exhaustively] satisfy",Array.prototype.map.call(valueDocument.childNodes,function(childNode){return convertDOMNodeToSatisfySpec(childNode,isHtml)}))});expect.exportAssertion(" to [exhaustively] satisfy ",function(expect,subject,value){var isHtml=isInsideHtmlDocument(subject);return expect(makeAttachedDOMNodeList(subject.childNodes),"to [exhaustively] satisfy",Array.prototype.map.call(value.childNodes,function(childNode){return convertDOMNodeToSatisfySpec(childNode,isHtml)}))});expect.exportAssertion(" to [exhaustively] satisfy ",function(expect,subject,value){return expect(subject,"to [exhaustively] satisfy",convertDOMNodeToSatisfySpec(value,isInsideHtmlDocument(subject)))});expect.exportAssertion(" to [exhaustively] satisfy ",function(expect,subject,value){expect.fail()});expect.exportAssertion(" to [exhaustively] satisfy ",function(expect,subject,value){expect.fail()});expect.exportAssertion(" to [exhaustively] satisfy ",function(expect,subject,value){var isHtml=isInsideHtmlDocument(subject);var unsupportedOptions=Object.keys(value).filter(function(key){return key!=="attributes"&&key!=="name"&&key!=="children"&&key!=="onlyAttributes"&&key!=="textContent"});if(unsupportedOptions.length>0){throw new Error("Unsupported option"+(unsupportedOptions.length===1?"":"s")+": "+unsupportedOptions.join(", "))}var promiseByKey={name:expect.promise(function(){if(value&&typeof value.name!=="undefined"){return topLevelExpect(isHtml?subject.nodeName.toLowerCase():subject.nodeName,"to satisfy",value.name)}}),children:expect.promise(function(){if(typeof value.children!=="undefined"){if(typeof value.textContent!=="undefined"){throw new Error("The children and textContent properties are not supported together")}return topLevelExpect(makeAttachedDOMNodeList(subject.childNodes,subject.ownerDocument.contentType),"to satisfy",value.children)}else if(typeof value.textContent!=="undefined"){return topLevelExpect(subject.textContent,"to satisfy",value.textContent)}}),attributes:{}};var onlyAttributes=value&&value.onlyAttributes||expect.flags.exhaustively;var attrs=getAttributes(subject);var expectedAttributes=value&&value.attributes;var expectedAttributeNames=[];if(typeof expectedAttributes!=="undefined"){if(typeof expectedAttributes==="string"){expectedAttributes=[expectedAttributes]}var expectedValueByAttributeName={};if(Array.isArray(expectedAttributes)){expectedAttributes.forEach(function(attributeName){expectedValueByAttributeName[attributeName]=true})}else if(expectedAttributes&&typeof expectedAttributes==="object"){expectedValueByAttributeName=expectedAttributes}Object.keys(expectedValueByAttributeName).forEach(function(attributeName){expectedAttributeNames.push(attributeName)});expectedAttributeNames.forEach(function(attributeName){var attributeValue=subject.getAttribute(attributeName);var expectedAttributeValue=expectedValueByAttributeName[attributeName];promiseByKey.attributes[attributeName]=expect.promise(function(){if(expectedAttributeValue===true){topLevelExpect(subject.hasAttribute(attributeName),"to be true")}else if(typeof expectedAttributeValue==="undefined"){topLevelExpect(subject.hasAttribute(attributeName),"to be false")}else if(attributeName==="class"&&(typeof expectedAttributeValue==="string"||Array.isArray(expectedAttributeValue))){var actualClasses=getClassNamesFromAttributeValue(attributeValue);var expectedClasses=expectedAttributeValue;if(typeof expectedClasses==="string"){expectedClasses=getClassNamesFromAttributeValue(expectedAttributeValue)}if(onlyAttributes){return topLevelExpect(actualClasses.sort(),"to equal",expectedClasses.sort())}else{return topLevelExpect.apply(topLevelExpect,[actualClasses,"to contain"].concat(expectedClasses))}}else if(attributeName==="style"){var expectedStyleObj;if(typeof expectedValueByAttributeName.style==="string"){expectedStyleObj=styleStringToObject(expectedValueByAttributeName.style)}else{expectedStyleObj=expectedValueByAttributeName.style}if(onlyAttributes){return topLevelExpect(attrs.style,"to exhaustively satisfy",expectedStyleObj)}else{return topLevelExpect(attrs.style,"to satisfy",expectedStyleObj)}}else{return topLevelExpect(attributeValue,"to satisfy",expectedAttributeValue)}})});promiseByKey.attributePresence=expect.promise(function(){var attributeNamesExpectedToBeDefined=[];expectedAttributeNames.forEach(function(attributeName){if(typeof expectedValueByAttributeName[attributeName]==="undefined"){expect(attrs,"not to have key",attributeName)}else{attributeNamesExpectedToBeDefined.push(attributeName);expect(attrs,"to have key",attributeName)}});if(onlyAttributes){expect(Object.keys(attrs).sort(),"to equal",attributeNamesExpectedToBeDefined.sort())}})}return expect.promise.all(promiseByKey).caught(function(){return expect.promise.settle(promiseByKey).then(function(){expect.fail({diff:function(output,diff,inspect,equal){output.block(function(){var output=this;var seenError=false;output.prismPunctuation("<").prismTag(isHtml?subject.nodeName.toLowerCase():subject.nodeName);if(promiseByKey.name.isRejected()){seenError=true;var nameError=promiseByKey.name.reason();output.sp().annotationBlock(function(){this.error(nameError&&nameError.getLabel()||"should satisfy").sp().append(inspect(value.name))})}var inspectedAttributes=[];Object.keys(attrs).forEach(function(attributeName){var attributeOutput=output.clone();var promise=promiseByKey.attributes[attributeName];writeAttributeToMagicPen(attributeOutput,attributeName,attrs[attributeName],isHtml);if(promise&&promise.isFulfilled()||!promise&&(!onlyAttributes||expectedAttributeNames.indexOf(attributeName)!==-1)){}else{seenError=true;attributeOutput.sp().annotationBlock(function(){if(promise&&typeof expectedValueByAttributeName[attributeName]!=="undefined"){this.append(promise.reason().getErrorMessage(this))}else{this.error("should be removed")}})}inspectedAttributes.push(attributeOutput)});expectedAttributeNames.forEach(function(attributeName){if(!subject.hasAttribute(attributeName)){var promise=promiseByKey.attributes[attributeName];if(!promise||promise.isRejected()){seenError=true;var err=promise&&promise.reason();var attributeOutput=output.clone().annotationBlock(function(){this.error("missing").sp().prismAttrName(attributeName,"html");if(expectedValueByAttributeName[attributeName]!==true){this.sp().error(err&&err.getLabel()||"should satisfy").sp().append(inspect(expectedValueByAttributeName[attributeName]))}});inspectedAttributes.push(attributeOutput)}}});if(inspectedAttributes.length>0){if(seenError){output.nl().indentLines().indent().block(function(output){inspectedAttributes.forEach(function(item,i){if(i>0){output.nl()}output.append(item)})}).outdentLines().nl()}else{output.sp();inspectedAttributes.forEach(function(item,i){if(i>0){output.sp()}output.append(item)})}}else if(seenError){output.nl()}output.prismPunctuation(">");var childrenError=promiseByKey.children.isRejected()&&promiseByKey.children.reason();if(childrenError){var childrenDiff=childrenError.getDiff(output);if(childrenDiff&&childrenDiff.inline){this.nl().indentLines().i().block(childrenDiff.diff).nl().outdentLines()}else{output.nl().indentLines().i().block(function(){for(var i=0;i to [only] have (attribute|attributes) ",function(expect,subject,value){return expect(subject,"to [only] have attributes",Array.prototype.slice.call(arguments,2))});expect.exportAssertion(" not to have (attribute|attributes) ",function(expect,subject,value){var attributes=getAttributes(subject);value.forEach(function(name){delete attributes[name]});return expect(subject,"to only have attributes",attributes)});expect.exportAssertion(" not to have (attribute|attributes) ",function(expect,subject,value){return expect(subject,"not to have attributes",Array.prototype.slice.call(arguments,2))});expect.exportAssertion(" to [only] have (attribute|attributes) ",function(expect,subject,value){return expect(subject,"to satisfy",{attributes:value,onlyAttributes:expect.flags.only})});expect.exportAssertion(" to have no (child|children)",function(expect,subject){expect.errorMode="nested";return expect(Array.prototype.slice.call(subject.childNodes),"to be an empty array")});expect.exportAssertion(" to have (child|children)",function(expect,subject){return expect(subject.childNodes,"not to be empty")});expect.exportAssertion(" to have (child|children) ",function(expect,subject,query){expect.errorMode="nested";expect(subject.querySelectorAll(query),"not to be empty")});expect.exportAssertion(" to have text ",function(expect,subject,value){return expect(subject.textContent,"to satisfy",value)});expect.exportAssertion(" [when] queried for [first] ",function(expect,subject,query){var queryResult;expect.argsOutput[0]=function(output){return output.green(query)};expect.errorMode="nested";if(expect.flags.first){queryResult=subject.querySelector(query);if(!queryResult){expect.fail(function(output){return output.error("The selector").sp().jsString(query).sp().error("yielded no results")})}}else{queryResult=subject.querySelectorAll(query);if(queryResult.length===0){expect.fail(function(output){return output.error("The selector").sp().jsString(query).sp().error("yielded no results")})}}return expect.shift(queryResult)});expect.exportAssertion(" to contain [no] elements matching ",function(expect,subject,query){if(expect.flags.no){return expect(subject.querySelectorAll(query),"to satisfy",[])}expect.subjectOutput=function(output){expect.inspect(subject,Infinity,output)};return expect(subject.querySelectorAll(query),"not to satisfy",[])});expect.exportAssertion(" [not] to match ",function(expect,subject,query){return expect(matchesSelector(subject,query),"to be",!expect.flags.not)});expect.exportAssertion(" [when] parsed as (html|HTML) [fragment] ",function(expect,subject){expect.errorMode="nested";return expect.shift(parseHtml(subject,expect.flags.fragment,expect.testDescription))});expect.exportAssertion(" [when] parsed as (xml|XML) ",function(expect,subject){expect.errorMode="nested";return expect.shift(parseXml(subject,expect.testDescription))})}}},{"./matchesSelector":2,"magicpen-prism":3}],2:[function(require,module,exports){module.exports=function(elm,selector){var matchFuntion=elm.matchesSelector||elm.mozMatchesSelector||elm.msMatchesSelector||elm.oMatchesSelector||elm.webkitMatchesSelector||function(selector){var node=this;var nodes=(node.parentNode||node.document).querySelectorAll(selector);var i=0;while(nodes[i]&&nodes[i]!==node){i+=1}return!!nodes[i]};return matchFuntion.call(elm,selector)}},{}],3:[function(require,module,exports){(function(global){var oldPrismGlobal=global.Prism;var prism=global.Prism=require("prismjs");require("prismjs/components/prism-graphql.js");require("prismjs/components/prism-csp.js");global.Prism=oldPrismGlobal;var defaultTheme={prismComment:"#708090",prismProlog:"prismComment",prismDoctype:"prismComment",prismCdata:"prismComment",prismPunctuation:"#999",prismSymbol:"#905",prismProperty:"prismSymbol",prismTag:"prismSymbol",prismBoolean:"prismSymbol",prismNumber:"prismSymbol",prismConstant:"prismSymbol",prismDeleted:"prismSymbol",prismString:"#690",prismSelector:"prismString",prismAttrName:"prismString",prismChar:"prismString",prismBuiltin:"prismString",prismInserted:"prismString",prismOperator:"#a67f59",prismVariable:"prismOperator",prismEntity:"prismOperator",prismUrl:"prismOperator",prismCssString:"prismOperator",prismKeyword:"#07a",prismAtrule:"prismKeyword",prismAttrValue:"prismKeyword",prismFunction:"#DD4A68",prismRegex:"#e90",prismImportant:["#e90","bold"]};var languageMapping={"text/html":"markup","application/xml":"markup","text/xml":"markup","application/json":"javascript","text/javascript":"javascript","application/javascript":"javascript","text/css":"css",html:"markup",xml:"markup",c:"clike","c++":"clike",cpp:"clike","c#":"clike",java:"clike","application/graphql":"graphql"};function upperCamelCase(str){return str.replace(/(?:^|-)([a-z])/g,function($0,ch){return ch.toUpperCase()})}module.exports={name:"magicpen-prism", -version:require("../package.json").version,installInto:function(magicPen){magicPen.installTheme(defaultTheme);magicPen.addStyle("code",function(sourceText,language){if(language in languageMapping){language=languageMapping[language]}else if(/\+xml\b/.test(language)){language="markup"}if(!(language in prism.languages)){return this.text(sourceText)}var that=this;var capitalizedLanguage=upperCamelCase(language);var languageDefinition=prism.languages[language];function printTokens(token,parentStyle){if(Array.isArray(token)){token.forEach(function(subToken){printTokens(subToken,parentStyle)})}else if(typeof token==="string"){var upperCamelCasedParentStyle=upperCamelCase(parentStyle);token=token.replace(/</g,"<");if(that["prism"+capitalizedLanguage+upperCamelCasedParentStyle]){that["prism"+capitalizedLanguage+upperCamelCasedParentStyle](token)}else if(that["prism"+upperCamelCasedParentStyle]){that["prism"+upperCamelCasedParentStyle](token)}else if(languageDefinition[parentStyle]&&languageDefinition[parentStyle].alias){printTokens(token,languageDefinition[parentStyle].alias)}else{that.text(token)}}else{printTokens(token.content,token.type)}}printTokens(prism.tokenize(sourceText,prism.languages[language]),"text")},true)}}}).call(this,typeof global!=="undefined"?global:typeof self!=="undefined"?self:typeof window!=="undefined"?window:{})},{"../package.json":4,prismjs:7,"prismjs/components/prism-csp.js":5,"prismjs/components/prism-graphql.js":6}],4:[function(require,module,exports){module.exports={_from:"magicpen-prism@^2.3.0",_id:"magicpen-prism@2.4.0",_inBundle:false,_integrity:"sha512-OEFZ+xksJtYgwnU5jJqDXhjvgnSFfMsSgXpJ2WWPaBJUXNKuQB0FBAiQxjRKsV5gntpg/tazH8L3apJx5eMdJg==",_location:"/magicpen-prism",_phantomChildren:{},_requested:{type:"range",registry:true,raw:"magicpen-prism@^2.3.0",name:"magicpen-prism",escapedName:"magicpen-prism",rawSpec:"^2.3.0",saveSpec:null,fetchSpec:"^2.3.0"},_requiredBy:["/"],_resolved:"https://registry.npmjs.org/magicpen-prism/-/magicpen-prism-2.4.0.tgz",_shasum:"aa79ca9b656f35069ad0aea8b102f1ac8642cbb0",_spec:"magicpen-prism@^2.3.0",_where:"/Users/ssimonsen/Code/unexpected-dom",author:{name:"Andreas Lind",email:"andreas@one.com"},bugs:{url:"https://github.com/unexpectedjs/magicpen-prism/issues"},bundleDependencies:false,dependencies:{prismjs:"1.11.0"},deprecated:false,description:"Add syntax highlighting support to magicpen via prism.js",devDependencies:{browserify:"13.0.0","bundle-collapser":"1.2.1",eslint:"2.13.1","eslint-config-onelint":"1.2.0",magicpen:"5.9.0",mocha:"2.4.5",unexpected:"10.10.5"},files:["lib","magicPenPrism.min.js"],homepage:"https://github.com/unexpectedjs/magicpen-prism#readme",main:"lib/magicPenPrism.js",name:"magicpen-prism",repository:{type:"git",url:"git+https://github.com/unexpectedjs/magicpen-prism.git"},scripts:{lint:"eslint .",prepublish:"browserify -p bundle-collapser/plugin -e lib/magicPenPrism -s magicPenPrism > magicPenPrism.min.js",test:"mocha",travis:"npm run lint && npm test"},version:"2.4.0"}},{}],5:[function(require,module,exports){Prism.languages.csp={directive:{pattern:/\b(?:(?:base-uri|form-action|frame-ancestors|plugin-types|referrer|reflected-xss|report-to|report-uri|require-sri-for|sandbox) |(?:block-all-mixed-content|disown-opener|upgrade-insecure-requests)(?: |;)|(?:child|connect|default|font|frame|img|manifest|media|object|script|style|worker)-src )/i,alias:"keyword"},safe:{pattern:/'(?:self|none|strict-dynamic|(?:nonce-|sha(?:256|384|512)-)[a-zA-Z0-9+=\/]+)'/,alias:"selector"},unsafe:{pattern:/(?:'unsafe-inline'|'unsafe-eval'|'unsafe-hashed-attributes'|\*)/,alias:"function"}}},{}],6:[function(require,module,exports){Prism.languages.graphql={comment:/#.*/,string:{pattern:/"(?:\\.|[^\\"\r\n])*"/,greedy:true},number:/(?:\B-|\b)\d+(?:\.\d+)?(?:[eE][+-]?\d+)?\b/,boolean:/\b(?:true|false)\b/,variable:/\$[a-z_]\w*/i,directive:{pattern:/@[a-z_]\w*/i,alias:"function"},"attr-name":/[a-z_]\w*(?=\s*:)/i,keyword:[{pattern:/(fragment\s+(?!on)[a-z_]\w*\s+|\.{3}\s*)on\b/,lookbehind:true},/\b(?:query|fragment|mutation)\b/],operator:/!|=|\.{3}/,punctuation:/[!(){}\[\]:=,]/}},{}],7:[function(require,module,exports){(function(global){var _self=typeof window!=="undefined"?window:typeof WorkerGlobalScope!=="undefined"&&self instanceof WorkerGlobalScope?self:{};var Prism=function(){var lang=/\blang(?:uage)?-(\w+)\b/i;var uniqueId=0;var _=_self.Prism={manual:_self.Prism&&_self.Prism.manual,disableWorkerMessageHandler:_self.Prism&&_self.Prism.disableWorkerMessageHandler,util:{encode:function(tokens){if(tokens instanceof Token){return new Token(tokens.type,_.util.encode(tokens.content),tokens.alias)}else if(_.util.type(tokens)==="Array"){return tokens.map(_.util.encode)}else{return tokens.replace(/&/g,"&").replace(/text.length){return}if(str instanceof Token){continue}pattern.lastIndex=0;var match=pattern.exec(str),delNum=1;if(!match&&greedy&&i!=strarr.length-1){pattern.lastIndex=pos;match=pattern.exec(text);if(!match){break}var from=match.index+(lookbehind?match[1].length:0),to=match.index+match[0].length,k=i,p=pos;for(var len=strarr.length;k=p){++i;pos=p}}if(strarr[i]instanceof Token||strarr[k-1].greedy){continue}delNum=k-i;str=text.slice(pos,p);match.index-=pos}if(!match){if(oneshot){break}continue}if(lookbehind){lookbehindLength=match[1].length}var from=match.index+lookbehindLength,match=match[0].slice(lookbehindLength),to=from+match.length,before=str.slice(0,from),after=str.slice(to);var args=[i,delNum];if(before){++i;pos+=before.length;args.push(before)}var wrapped=new Token(token,inside?_.tokenize(match,inside):match,alias,match,greedy);args.push(wrapped);if(after){args.push(after)}Array.prototype.splice.apply(strarr,args);if(delNum!=1)_.matchGrammar(text,strarr,grammar,i,pos,true,token);if(oneshot)break}}}},tokenize:function(text,grammar,language){var strarr=[text];var rest=grammar.rest;if(rest){for(var token in rest){grammar[token]=rest[token]}delete grammar.rest}_.matchGrammar(text,strarr,grammar,0,0,false);return strarr},hooks:{all:{},add:function(name,callback){var hooks=_.hooks.all;hooks[name]=hooks[name]||[];hooks[name].push(callback)},run:function(name,env){var callbacks=_.hooks.all[name];if(!callbacks||!callbacks.length){return}for(var i=0,callback;callback=callbacks[i++];){callback(env)}}}};var Token=_.Token=function(type,content,alias,matchedStr,greedy){this.type=type;this.content=content;this.alias=alias;this.length=(matchedStr||"").length|0;this.greedy=!!greedy};Token.stringify=function(o,language,parent){if(typeof o=="string"){return o}if(_.util.type(o)==="Array"){return o.map(function(element){return Token.stringify(element,language,o)}).join("")}var env={type:o.type,content:Token.stringify(o.content,language,parent),tag:"span",classes:["token",o.type],attributes:{},language:language,parent:parent};if(o.alias){var aliases=_.util.type(o.alias)==="Array"?o.alias:[o.alias];Array.prototype.push.apply(env.classes,aliases)}_.hooks.run("wrap",env);var attributes=Object.keys(env.attributes).map(function(name){return name+'="'+(env.attributes[name]||"").replace(/"/g,""")+'"'}).join(" ");return"<"+env.tag+' class="'+env.classes.join(" ")+'"'+(attributes?" "+attributes:"")+">"+env.content+""};if(!_self.document){if(!_self.addEventListener){return _self.Prism}if(!_.disableWorkerMessageHandler){_self.addEventListener("message",function(evt){var message=JSON.parse(evt.data),lang=message.language,code=message.code,immediateClose=message.immediateClose;_self.postMessage(_.highlight(code,_.languages[lang],lang));if(immediateClose){_self.close()}},false)}return _self.Prism}var script=document.currentScript||[].slice.call(document.getElementsByTagName("script")).pop();if(script){_.filename=script.src;if(!_.manual&&!script.hasAttribute("data-manual")){if(document.readyState!=="loading"){if(window.requestAnimationFrame){window.requestAnimationFrame(_.highlightAll)}else{window.setTimeout(_.highlightAll,16)}}else{document.addEventListener("DOMContentLoaded",_.highlightAll)}}}return _self.Prism}();if(typeof module!=="undefined"&&module.exports){module.exports=Prism}if(typeof global!=="undefined"){global.Prism=Prism}Prism.languages.markup={comment://,prolog:/<\?[\s\S]+?\?>/,doctype://i,cdata://i,tag:{pattern:/<\/?(?!\d)[^\s>\/=$<]+(?:\s+[^\s>\/=]+(?:=(?:("|')(?:\\[\s\S]|(?!\1)[^\\])*\1|[^\s'">=]+))?)*\s*\/?>/i,inside:{tag:{pattern:/^<\/?[^\s>\/]+/i,inside:{punctuation:/^<\/?/,namespace:/^[^\s>\/:]+:/}},"attr-value":{pattern:/=(?:("|')(?:\\[\s\S]|(?!\1)[^\\])*\1|[^\s'">=]+)/i,inside:{punctuation:[/^=/,{pattern:/(^|[^\\])["']/,lookbehind:true}]}},punctuation:/\/?>/,"attr-name":{pattern:/[^\s>\/]+/,inside:{namespace:/^[^\s>\/:]+:/}}}},entity:/&#?[\da-z]{1,8};/i};Prism.languages.markup["tag"].inside["attr-value"].inside["entity"]=Prism.languages.markup["entity"];Prism.hooks.add("wrap",function(env){if(env.type==="entity"){env.attributes["title"]=env.content.replace(/&/,"&")}});Prism.languages.xml=Prism.languages.markup;Prism.languages.html=Prism.languages.markup;Prism.languages.mathml=Prism.languages.markup;Prism.languages.svg=Prism.languages.markup;Prism.languages.css={comment:/\/\*[\s\S]*?\*\//,atrule:{pattern:/@[\w-]+?.*?(?:;|(?=\s*\{))/i,inside:{rule:/@[\w-]+/}},url:/url\((?:(["'])(?:\\(?:\r\n|[\s\S])|(?!\1)[^\\\r\n])*\1|.*?)\)/i,selector:/[^{}\s][^{};]*?(?=\s*\{)/,string:{pattern:/("|')(?:\\(?:\r\n|[\s\S])|(?!\1)[^\\\r\n])*\1/,greedy:true},property:/[-_a-z\xA0-\uFFFF][-\w\xA0-\uFFFF]*(?=\s*:)/i,important:/\B!important\b/i,function:/[-a-z0-9]+(?=\()/i,punctuation:/[(){};:]/};Prism.languages.css["atrule"].inside.rest=Prism.util.clone(Prism.languages.css);if(Prism.languages.markup){Prism.languages.insertBefore("markup","tag",{style:{pattern:/()[\s\S]*?(?=<\/style>)/i,lookbehind:true,inside:Prism.languages.css,alias:"language-css",greedy:true}});Prism.languages.insertBefore("inside","attr-value",{"style-attr":{pattern:/\s*style=("|')(?:\\[\s\S]|(?!\1)[^\\])*\1/i,inside:{"attr-name":{pattern:/^\s*style/i,inside:Prism.languages.markup.tag.inside},punctuation:/^\s*=\s*['"]|['"]\s*$/,"attr-value":{pattern:/.+/i,inside:Prism.languages.css}},alias:"language-css"}},Prism.languages.markup.tag)}Prism.languages.clike={comment:[{pattern:/(^|[^\\])\/\*[\s\S]*?(?:\*\/|$)/,lookbehind:true},{pattern:/(^|[^\\:])\/\/.*/,lookbehind:true}],string:{pattern:/(["'])(?:\\(?:\r\n|[\s\S])|(?!\1)[^\\\r\n])*\1/,greedy:true},"class-name":{pattern:/((?:\b(?:class|interface|extends|implements|trait|instanceof|new)\s+)|(?:catch\s+\())[\w.\\]+/i,lookbehind:true,inside:{punctuation:/[.\\]/}},keyword:/\b(?:if|else|while|do|for|return|in|instanceof|function|new|try|throw|catch|finally|null|break|continue)\b/,boolean:/\b(?:true|false)\b/,function:/[a-z0-9_]+(?=\()/i,number:/\b-?(?:0x[\da-f]+|\d*\.?\d+(?:e[+-]?\d+)?)\b/i,operator:/--?|\+\+?|!=?=?|<=?|>=?|==?=?|&&?|\|\|?|\?|\*|\/|~|\^|%/,punctuation:/[{}[\];(),.:]/};Prism.languages.javascript=Prism.languages.extend("clike",{keyword:/\b(?:as|async|await|break|case|catch|class|const|continue|debugger|default|delete|do|else|enum|export|extends|finally|for|from|function|get|if|implements|import|in|instanceof|interface|let|new|null|of|package|private|protected|public|return|set|static|super|switch|this|throw|try|typeof|var|void|while|with|yield)\b/,number:/\b-?(?:0[xX][\dA-Fa-f]+|0[bB][01]+|0[oO][0-7]+|\d*\.?\d+(?:[Ee][+-]?\d+)?|NaN|Infinity)\b/,function:/[_$a-z\xA0-\uFFFF][$\w\xA0-\uFFFF]*(?=\s*\()/i,operator:/-[-=]?|\+[+=]?|!=?=?|<>?>?=?|=(?:==?|>)?|&[&=]?|\|[|=]?|\*\*?=?|\/=?|~|\^=?|%=?|\?|\.{3}/});Prism.languages.insertBefore("javascript","keyword",{regex:{pattern:/(^|[^\/])\/(?!\/)(\[[^\]\r\n]+]|\\.|[^\/\\\[\r\n])+\/[gimyu]{0,5}(?=\s*($|[\r\n,.;})]))/,lookbehind:true,greedy:true},"function-variable":{pattern:/[_$a-z\xA0-\uFFFF][$\w\xA0-\uFFFF]*(?=\s*=\s*(?:function\b|(?:\([^()]*\)|[_$a-z\xA0-\uFFFF][$\w\xA0-\uFFFF]*)\s*=>))/i,alias:"function"}});Prism.languages.insertBefore("javascript","string",{"template-string":{pattern:/`(?:\\[\s\S]|[^\\`])*`/,greedy:true,inside:{interpolation:{pattern:/\$\{[^}]+\}/,inside:{"interpolation-punctuation":{pattern:/^\$\{|\}$/,alias:"punctuation"},rest:Prism.languages.javascript}},string:/[\s\S]+/}}});if(Prism.languages.markup){Prism.languages.insertBefore("markup","tag",{script:{pattern:/()[\s\S]*?(?=<\/script>)/i,lookbehind:true,inside:Prism.languages.javascript,alias:"language-javascript",greedy:true}})}Prism.languages.js=Prism.languages.javascript;(function(){if(typeof self==="undefined"||!self.Prism||!self.document||!document.querySelector){return}self.Prism.fileHighlight=function(){var Extensions={js:"javascript",py:"python",rb:"ruby",ps1:"powershell",psm1:"powershell",sh:"bash",bat:"batch",h:"c",tex:"latex"};Array.prototype.slice.call(document.querySelectorAll("pre[data-src]")).forEach(function(pre){var src=pre.getAttribute("data-src");var language,parent=pre;var lang=/\blang(?:uage)?-(?!\*)(\w+)\b/i;while(parent&&!lang.test(parent.className)){parent=parent.parentNode}if(parent){language=(pre.className.match(lang)||[,""])[1]}if(!language){var extension=(src.match(/\.(\w+)$/)||[,""])[1];language=Extensions[extension]||extension}var code=document.createElement("code");code.className="language-"+language;pre.textContent="";code.textContent="Loading…";pre.appendChild(code);var xhr=new XMLHttpRequest;xhr.open("GET",src,true);xhr.onreadystatechange=function(){if(xhr.readyState==4){if(xhr.status<400&&xhr.responseText){code.textContent=xhr.responseText;Prism.highlightElement(code)}else if(xhr.status>=400){code.textContent="✖ Error "+xhr.status+" while fetching file: "+xhr.statusText}else{code.textContent="✖ Error: File does not exist or is empty"}}};xhr.send(null)})};document.addEventListener("DOMContentLoaded",self.Prism.fileHighlight)})()}).call(this,typeof global!=="undefined"?global:typeof self!=="undefined"?self:typeof window!=="undefined"?window:{})},{}]},{},[1])(1)}); +(function(f){if(typeof exports==="object"&&typeof module!=="undefined"){module.exports=f()}else if(typeof define==="function"&&define.amd){define([],f)}else{var g;if(typeof window!=="undefined"){g=window}else if(typeof global!=="undefined"){g=global}else if(typeof self!=="undefined"){g=self}else{g=this}(g.unexpected||(g.unexpected={})).dom=f()}})(function(){var define,module,exports;return function(){function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require=="function"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error("Cannot find module '"+o+"'");throw f.code="MODULE_NOT_FOUND",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require=="function"&&require;for(var o=0;o"}var htmlDocument;if(typeof DOMParser!=="undefined"){htmlDocument=(new DOMParser).parseFromString(str,"text/html")}else if(typeof document!=="undefined"&&document.implementation&&document.implementation.createHTMLDocument){htmlDocument=document.implementation.createHTMLDocument("");htmlDocument.open();htmlDocument.write(str);htmlDocument.close()}else{var jsdom;try{jsdom=require(""+"jsdom")}catch(err){throw new Error("unexpected-dom"+(assertionNameForErrorMessage?" ("+assertionNameForErrorMessage+")":"")+": Running outside a browser, but could not find the `jsdom` module. Please npm install jsdom to make this work.")}if(jsdom.JSDOM){htmlDocument=new jsdom.JSDOM(str).window.document}else{htmlDocument=jsdom.jsdom(str)}}if(isFragment){var body=htmlDocument.body;var documentFragment=htmlDocument.createDocumentFragment();if(body){for(var i=0;i"}}module.exports={name:"unexpected-dom",installInto:function(expect){expect=expect.child();expect.use(require("magicpen-prism"));var topLevelExpect=expect;expect.exportType({name:"DOMNode",base:"object",identify:function(obj){return obj&&obj.nodeName&&[2,3,4,5,6,7,10,11,12].indexOf(obj.nodeType)>-1},equal:function(a,b){return a.nodeValue===b.nodeValue},inspect:function(element,depth,output){return output.code(element.nodeName+' "'+element.nodeValue+'"',"prism-string")}});expect.exportType({name:"DOMComment",base:"DOMNode",identify:function(obj){return obj&&typeof obj.nodeType==="number"&&obj.nodeType===8},equal:function(a,b){return a.nodeValue===b.nodeValue},inspect:function(element,depth,output){return output.code("\x3c!--"+element.nodeValue+"--\x3e","html")},diff:function(actual,expected,output,diff,inspect,equal){var d=diff("\x3c!--"+actual.nodeValue+"--\x3e","\x3c!--"+expected.nodeValue+"--\x3e");d.inline=true;return d}});expect.exportType({name:"DOMTextNode",base:"DOMNode",identify:function(obj){return obj&&typeof obj.nodeType==="number"&&obj.nodeType===3},equal:function(a,b){return a.nodeValue===b.nodeValue},inspect:function(element,depth,output){return output.code(entitify(element.nodeValue.trim()),"html")},diff:function(actual,expected,output,diff,inspect,equal){var d=diff(actual.nodeValue,expected.nodeValue);d.inline=true;return d}});expect.exportType({name:"DOMNodeList",base:"array-like",prefix:function(output){return output.text("NodeList[")},suffix:function(output){return output.text("]")},similar:function(a,b){return a.nodeType===1&&b.nodeType===1&&a.nodeName===b.nodeName},identify:function(obj){return obj&&typeof obj.length==="number"&&typeof obj.toString==="function"&&typeof obj.item==="function"&&(obj.toString().indexOf("NodeList")!==-1||obj.constructor&&obj.constructor.name==="NodeList")}});expect.exportType({name:"attachedDOMNodeList",base:"DOMNodeList",indent:false,prefix:function(output){return output},suffix:function(output){return output},delimiter:function(output){return output},identify:function(obj){return obj&&obj._isAttachedDOMNodeList}});function makeAttachedDOMNodeList(domNodeList,contentType){var attachedDOMNodeList=[];for(var i=0;i","html")},equal:function(a,b){return a.toString()===b.toString()},diff:function(actual,expected,output,diff){var d=diff("","");d.inline=true;return d}});expect.exportType({name:"DOMDocument",base:"DOMNode",identify:function(obj){return obj&&typeof obj.nodeType==="number"&&obj.nodeType===9&&obj.documentElement&&obj.implementation},inspect:function(document,depth,output,inspect){for(var i=0;i',"xml");for(var i=0;i0){if(depth===1){output.text("...")}else{var inspectedChildren=[];if(elementName==="script"){var type=element.getAttribute("type");if(!type||/javascript/.test(type)){type="javascript"}inspectedChildren.push(output.clone().code(element.textContent,type))}else if(elementName==="style"){inspectedChildren.push(output.clone().code(element.textContent,element.getAttribute("type")||"text/css"))}else{for(var i=0;i60||o.height>1});if(multipleLines){output.nl().indentLines();inspectedChildren.forEach(function(inspectedChild,index){output.i().block(inspectedChild).nl()});output.outdentLines()}else{inspectedChildren.forEach(function(inspectedChild,index){output.append(inspectedChild)})}}}output.code(stringifyEndTag(element),"html");return output},diffLimit:512,diff:function(actual,expected,output,diff,inspect,equal){var isHtml=isInsideHtmlDocument(actual);output.inline=true;if(Math.max(actual.length,expected.length)>this.diffLimit){output.jsComment("Diff suppressed due to size > "+this.diffLimit);return output}var emptyElements=actual.childNodes.length===0&&expected.childNodes.length===0;var conflictingElement=actual.nodeName.toLowerCase()!==expected.nodeName.toLowerCase()||!equal(getAttributes(actual),getAttributes(expected));if(conflictingElement){var canContinueLine=true;output.prismPunctuation("<").prismTag(actual.nodeName.toLowerCase());if(actual.nodeName.toLowerCase()!==expected.nodeName.toLowerCase()){output.sp().annotationBlock(function(){this.error("should be").sp().prismTag(expected.nodeName.toLowerCase())}).nl();canContinueLine=false}var actualAttributes=getAttributes(actual);var expectedAttributes=getAttributes(expected);Object.keys(actualAttributes).forEach(function(attributeName){output.sp(canContinueLine?1:2+actual.nodeName.length);writeAttributeToMagicPen(output,attributeName,actualAttributes[attributeName],isHtml);if(attributeName in expectedAttributes){if(actualAttributes[attributeName]===expectedAttributes[attributeName]){canContinueLine=true}else{output.sp().annotationBlock(function(){this.error("should equal").sp().append(inspect(entitify(expectedAttributes[attributeName])))}).nl();canContinueLine=false}delete expectedAttributes[attributeName]}else{output.sp().annotationBlock(function(){this.error("should be removed")}).nl();canContinueLine=false}});Object.keys(expectedAttributes).forEach(function(attributeName){output.sp(canContinueLine?1:2+actual.nodeName.length);output.annotationBlock(function(){this.error("missing").sp();writeAttributeToMagicPen(this,attributeName,expectedAttributes[attributeName],isHtml)}).nl();canContinueLine=false});output.prismPunctuation(">")}else{output.code(stringifyStartTag(actual),"html")}if(!emptyElements){output.nl().indentLines().i().block(diff(makeAttachedDOMNodeList(actual.childNodes),makeAttachedDOMNodeList(expected.childNodes)).diff).nl().outdentLines()}output.code(stringifyEndTag(actual),"html");return output}});expect.exportAssertion(" to have (class|classes) ",function(expect,subject,value){return expect(subject,"to have attributes",{class:value})});expect.exportAssertion(" to only have (class|classes) ",function(expect,subject,value){return expect(subject,"to have attributes",{class:function(className){var actualClasses=getClassNamesFromAttributeValue(className);if(typeof value==="string"){value=getClassNamesFromAttributeValue(value)}return topLevelExpect(actualClasses.sort(),"to equal",value.sort())}})});expect.exportAssertion(" to [exhaustively] satisfy ",function(expect,subject,value){return expect(subject.nodeValue,"to equal",value.nodeValue)});expect.exportAssertion(" to [exhaustively] satisfy ",function(expect,subject,value){expect.fail()});expect.exportAssertion(" to [exhaustively] satisfy ",function(expect,subject,value){return expect(subject.nodeValue,"to satisfy",value)});expect.exportAssertion(" to [exhaustively] satisfy ",function(expect,subject,value){return expect(subject.nodeValue,"to satisfy",value)});function convertDOMNodeToSatisfySpec(node,isHtml){if(node.nodeType===8&&node.nodeValue.trim()==="ignore"){return{}}else if(node.nodeType===10){return{name:node.nodeName}}else if(node.nodeType===1){var name=isHtml?node.nodeName.toLowerCase():node.nodeName;if(name==="ignore"){return{}}var result={name:name};if(node.attributes){result.attributes={};for(var i=0;i to [exhaustively] satisfy ",function(expect,subject,value){var isHtml=subject.ownerDocument.contentType==="text/html";expect.argsOutput=function(output){return output.code(value,isHtml?"html":"xml")};return expect(subject,"to [exhaustively] satisfy",(isHtml?parseHtml(value,true,expect.testDescription):parseXml(value,expect.testDescription)).childNodes)});expect.exportAssertion(" to [exhaustively] satisfy ",function(expect,subject,value){var isHtml=subject.ownerDocument.contentType==="text/html";var satisfySpecs=[];for(var i=0;i to [exhaustively] satisfy ",function(expect,subject,value){var isHtml=isInsideHtmlDocument(subject);expect.argsOutput=function(output){return output.code(value,isHtml?"html":"xml")};return expect(subject,"to [exhaustively] satisfy",isHtml?parseHtml(value,true,expect.testDescription):parseXml(value,expect.testDescription))});expect.exportAssertion(" to [exhaustively] satisfy ",function(expect,subject,value){var isHtml=subject.ownerDocument.contentType==="text/html";return expect(subject,"to [exhaustively] satisfy",Array.prototype.map.call(value.childNodes,function(childNode){return convertDOMNodeToSatisfySpec(childNode,isHtml)}))});expect.exportAssertion(" to [exhaustively] satisfy ",function(expect,subject,value){return expect(subject.childNodes,"to [exhaustively] satisfy",value)});expect.exportAssertion(" to [exhaustively] satisfy ",function(expect,subject,value){var isHtml=isInsideHtmlDocument(subject);var documentFragment=isHtml?parseHtml(value,true,this.testDescription):parseXml(value,this.testDescription);if(documentFragment.childNodes.length!==1){throw new Error("HTMLElement to satisfy string: Only a single node is supported")}expect.argsOutput=function(output){return output.code(value,isHtml?"html":"xml")};return expect(subject,"to [exhaustively] satisfy",documentFragment.childNodes[0])});expect.exportAssertion(" to [exhaustively] satisfy ",function(expect,subject,value){var isHtml=isInsideHtmlDocument(subject);var valueDocument=isHtml?parseHtml(value,false,this.testDescription):parseXml(value,this.testDescription);return expect(makeAttachedDOMNodeList(subject.childNodes),"to [exhaustively] satisfy",Array.prototype.map.call(valueDocument.childNodes,function(childNode){return convertDOMNodeToSatisfySpec(childNode,isHtml)}))});expect.exportAssertion(" to [exhaustively] satisfy ",function(expect,subject,value){var isHtml=isInsideHtmlDocument(subject);return expect(makeAttachedDOMNodeList(subject.childNodes),"to [exhaustively] satisfy",Array.prototype.map.call(value.childNodes,function(childNode){return convertDOMNodeToSatisfySpec(childNode,isHtml)}))});expect.exportAssertion(" to [exhaustively] satisfy ",function(expect,subject,value){return expect(subject,"to [exhaustively] satisfy",convertDOMNodeToSatisfySpec(value,isInsideHtmlDocument(subject)))});expect.exportAssertion(" to [exhaustively] satisfy ",function(expect,subject,value){expect.fail()});expect.exportAssertion(" to [exhaustively] satisfy ",function(expect,subject,value){expect.fail()});expect.exportAssertion(" to [exhaustively] satisfy ",function(expect,subject,value){var isHtml=isInsideHtmlDocument(subject);var unsupportedOptions=Object.keys(value).filter(function(key){return key!=="attributes"&&key!=="name"&&key!=="children"&&key!=="onlyAttributes"&&key!=="textContent"});if(unsupportedOptions.length>0){throw new Error("Unsupported option"+(unsupportedOptions.length===1?"":"s")+": "+unsupportedOptions.join(", "))}var promiseByKey={name:expect.promise(function(){if(value&&typeof value.name!=="undefined"){return topLevelExpect(isHtml?subject.nodeName.toLowerCase():subject.nodeName,"to satisfy",value.name)}}),children:expect.promise(function(){if(typeof value.children!=="undefined"){if(typeof value.textContent!=="undefined"){throw new Error("The children and textContent properties are not supported together")}return topLevelExpect(makeAttachedDOMNodeList(subject.childNodes,subject.ownerDocument.contentType),"to satisfy",value.children)}else if(typeof value.textContent!=="undefined"){return topLevelExpect(subject.textContent,"to satisfy",value.textContent)}}),attributes:{}};var onlyAttributes=value&&value.onlyAttributes||expect.flags.exhaustively;var attrs=getAttributes(subject);var expectedAttributes=value&&value.attributes;var expectedAttributeNames=[];if(typeof expectedAttributes!=="undefined"){if(typeof expectedAttributes==="string"){expectedAttributes=[expectedAttributes]}var expectedValueByAttributeName={};if(Array.isArray(expectedAttributes)){expectedAttributes.forEach(function(attributeName){expectedValueByAttributeName[attributeName]=true})}else if(expectedAttributes&&typeof expectedAttributes==="object"){expectedValueByAttributeName=expectedAttributes}Object.keys(expectedValueByAttributeName).forEach(function(attributeName){expectedAttributeNames.push(attributeName)});expectedAttributeNames.forEach(function(attributeName){var attributeValue=subject.getAttribute(attributeName);var expectedAttributeValue=expectedValueByAttributeName[attributeName];promiseByKey.attributes[attributeName]=expect.promise(function(){if(expectedAttributeValue===true){topLevelExpect(subject.hasAttribute(attributeName),"to be true")}else if(typeof expectedAttributeValue==="undefined"){topLevelExpect(subject.hasAttribute(attributeName),"to be false")}else if(attributeName==="class"&&(typeof expectedAttributeValue==="string"||Array.isArray(expectedAttributeValue))){var actualClasses=getClassNamesFromAttributeValue(attributeValue);var expectedClasses=expectedAttributeValue;if(typeof expectedClasses==="string"){expectedClasses=getClassNamesFromAttributeValue(expectedAttributeValue)}if(onlyAttributes){return topLevelExpect(actualClasses.sort(),"to equal",expectedClasses.sort())}else{return topLevelExpect.apply(topLevelExpect,[actualClasses,"to contain"].concat(expectedClasses))}}else if(attributeName==="style"){var expectedStyleObj;if(typeof expectedValueByAttributeName.style==="string"){expectedStyleObj=styleStringToObject(expectedValueByAttributeName.style)}else{expectedStyleObj=expectedValueByAttributeName.style}if(onlyAttributes){return topLevelExpect(attrs.style,"to exhaustively satisfy",expectedStyleObj)}else{return topLevelExpect(attrs.style,"to satisfy",expectedStyleObj)}}else{return topLevelExpect(attributeValue,"to satisfy",expectedAttributeValue)}})});promiseByKey.attributePresence=expect.promise(function(){var attributeNamesExpectedToBeDefined=[];expectedAttributeNames.forEach(function(attributeName){if(typeof expectedValueByAttributeName[attributeName]==="undefined"){expect(attrs,"not to have key",attributeName)}else{attributeNamesExpectedToBeDefined.push(attributeName);expect(attrs,"to have key",attributeName)}});if(onlyAttributes){expect(Object.keys(attrs).sort(),"to equal",attributeNamesExpectedToBeDefined.sort())}})}return expect.promise.all(promiseByKey).caught(function(){return expect.promise.settle(promiseByKey).then(function(){expect.fail({diff:function(output,diff,inspect,equal){output.block(function(){var output=this;var seenError=false;output.prismPunctuation("<").prismTag(isHtml?subject.nodeName.toLowerCase():subject.nodeName);if(promiseByKey.name.isRejected()){seenError=true;var nameError=promiseByKey.name.reason();output.sp().annotationBlock(function(){this.error(nameError&&nameError.getLabel()||"should satisfy").sp().append(inspect(value.name))})}var inspectedAttributes=[];Object.keys(attrs).forEach(function(attributeName){var attributeOutput=output.clone();var promise=promiseByKey.attributes[attributeName];writeAttributeToMagicPen(attributeOutput,attributeName,attrs[attributeName],isHtml);if(promise&&promise.isFulfilled()||!promise&&(!onlyAttributes||expectedAttributeNames.indexOf(attributeName)!==-1)){}else{seenError=true;attributeOutput.sp().annotationBlock(function(){if(promise&&typeof expectedValueByAttributeName[attributeName]!=="undefined"){this.append(promise.reason().getErrorMessage(this))}else{this.error("should be removed")}})}inspectedAttributes.push(attributeOutput)});expectedAttributeNames.forEach(function(attributeName){if(!subject.hasAttribute(attributeName)){var promise=promiseByKey.attributes[attributeName];if(!promise||promise.isRejected()){seenError=true;var err=promise&&promise.reason();var attributeOutput=output.clone().annotationBlock(function(){this.error("missing").sp().prismAttrName(attributeName,"html");if(expectedValueByAttributeName[attributeName]!==true){this.sp().error(err&&err.getLabel()||"should satisfy").sp().append(inspect(expectedValueByAttributeName[attributeName]))}});inspectedAttributes.push(attributeOutput)}}});if(inspectedAttributes.length>0){if(seenError){output.nl().indentLines().indent().block(function(output){inspectedAttributes.forEach(function(item,i){if(i>0){output.nl()}output.append(item)})}).outdentLines().nl()}else{output.sp();inspectedAttributes.forEach(function(item,i){if(i>0){output.sp()}output.append(item)})}}else if(seenError){output.nl()}output.prismPunctuation(">");var childrenError=promiseByKey.children.isRejected()&&promiseByKey.children.reason();if(childrenError){var childrenDiff=childrenError.getDiff(output);if(childrenDiff&&childrenDiff.inline){this.nl().indentLines().i().block(childrenDiff.diff).nl().outdentLines()}else{output.nl().indentLines().i().block(function(){for(var i=0;i to [only] have (attribute|attributes) ",function(expect,subject,value){return expect(subject,"to [only] have attributes",Array.prototype.slice.call(arguments,2))});expect.exportAssertion(" not to have (attribute|attributes) ",function(expect,subject,value){var attributes=getAttributes(subject);value.forEach(function(name){delete attributes[name]});return expect(subject,"to only have attributes",attributes)});expect.exportAssertion(" not to have (attribute|attributes) ",function(expect,subject,value){return expect(subject,"not to have attributes",Array.prototype.slice.call(arguments,2))});expect.exportAssertion(" to [only] have (attribute|attributes) ",function(expect,subject,value){return expect(subject,"to satisfy",{attributes:value,onlyAttributes:expect.flags.only})});expect.exportAssertion(" to have no (child|children)",function(expect,subject){expect.errorMode="nested";return expect(Array.prototype.slice.call(subject.childNodes),"to be an empty array")});expect.exportAssertion(" to have (child|children)",function(expect,subject){return expect(subject.childNodes,"not to be empty")});expect.exportAssertion(" to have (child|children) ",function(expect,subject,query){expect.errorMode="nested";expect(subject.querySelectorAll(query),"not to be empty")});expect.exportAssertion(" to have text ",function(expect,subject,value){return expect(subject.textContent,"to satisfy",value)});expect.exportAssertion(" [when] queried for [first] ",function(expect,subject,query){var queryResult;expect.argsOutput[0]=function(output){return output.green(query)};expect.errorMode="nested";if(expect.flags.first){queryResult=subject.querySelector(query);if(!queryResult){expect.fail(function(output){return output.error("The selector").sp().jsString(query).sp().error("yielded no results")})}}else{queryResult=subject.querySelectorAll(query);if(queryResult.length===0){expect.fail(function(output){return output.error("The selector").sp().jsString(query).sp().error("yielded no results")})}}return expect.shift(queryResult)});expect.exportAssertion(" to contain [no] elements matching ",function(expect,subject,query){if(expect.flags.no){return expect(subject.querySelectorAll(query),"to satisfy",[])}expect.subjectOutput=function(output){expect.inspect(subject,Infinity,output)};return expect(subject.querySelectorAll(query),"not to satisfy",[])});expect.exportAssertion(" [not] to match ",function(expect,subject,query){return expect(matchesSelector(subject,query),"to be",!expect.flags.not)});expect.exportAssertion(" [when] parsed as (html|HTML) [fragment] ",function(expect,subject){expect.errorMode="nested";return expect.shift(parseHtml(subject,expect.flags.fragment,expect.testDescription))});expect.exportAssertion(" [when] parsed as (xml|XML) ",function(expect,subject){expect.errorMode="nested";return expect.shift(parseXml(subject,expect.testDescription))})}}},{"./matchesSelector":2,"magicpen-prism":3}],2:[function(require,module,exports){module.exports=function(elm,selector){var matchFuntion=elm.matchesSelector||elm.mozMatchesSelector||elm.msMatchesSelector||elm.oMatchesSelector||elm.webkitMatchesSelector||function(selector){var node=this;var nodes=(node.parentNode||node.document).querySelectorAll(selector);var i=0;while(nodes[i]&&nodes[i]!==node){i+=1}return!!nodes[i]};return matchFuntion.call(elm,selector)}},{}],3:[function(require,module,exports){(function(global){var oldPrismGlobal=global.Prism;var prism=global.Prism=require("prismjs");require("prismjs/components/prism-graphql.js");require("prismjs/components/prism-csp.js");global.Prism=oldPrismGlobal;var defaultTheme={prismComment:"#708090",prismProlog:"prismComment",prismDoctype:"prismComment",prismCdata:"prismComment",prismPunctuation:"#999",prismSymbol:"#905",prismProperty:"prismSymbol",prismTag:"prismSymbol",prismBoolean:"prismSymbol",prismNumber:"prismSymbol",prismConstant:"prismSymbol",prismDeleted:"prismSymbol",prismString:"#690",prismSelector:"prismString",prismAttrName:"prismString",prismChar:"prismString",prismBuiltin:"prismString",prismInserted:"prismString",prismOperator:"#a67f59",prismVariable:"prismOperator",prismEntity:"prismOperator",prismUrl:"prismOperator",prismCssString:"prismOperator",prismKeyword:"#07a",prismAtrule:"prismKeyword",prismAttrValue:"prismKeyword",prismFunction:"#DD4A68",prismRegex:"#e90",prismImportant:["#e90","bold"]};var languageMapping={"text/html":"markup","application/xml":"markup","text/xml":"markup","application/json":"javascript","text/javascript":"javascript","application/javascript":"javascript","text/css":"css",html:"markup",xml:"markup",c:"clike","c++":"clike",cpp:"clike","c#":"clike",java:"clike","application/graphql":"graphql"};function upperCamelCase(str){return str.replace(/(?:^|-)([a-z])/g,function($0,ch){return ch.toUpperCase()})}module.exports={ +name:"magicpen-prism",version:require("../package.json").version,installInto:function(magicPen){magicPen.installTheme(defaultTheme);magicPen.addStyle("code",function(sourceText,language){if(language in languageMapping){language=languageMapping[language]}else if(/\+xml\b/.test(language)){language="markup"}if(!(language in prism.languages)){return this.text(sourceText)}var that=this;var capitalizedLanguage=upperCamelCase(language);var languageDefinition=prism.languages[language];function printTokens(token,parentStyle){if(Array.isArray(token)){token.forEach(function(subToken){printTokens(subToken,parentStyle)})}else if(typeof token==="string"){var upperCamelCasedParentStyle=upperCamelCase(parentStyle);token=token.replace(/</g,"<");if(that["prism"+capitalizedLanguage+upperCamelCasedParentStyle]){that["prism"+capitalizedLanguage+upperCamelCasedParentStyle](token)}else if(that["prism"+upperCamelCasedParentStyle]){that["prism"+upperCamelCasedParentStyle](token)}else if(languageDefinition[parentStyle]&&languageDefinition[parentStyle].alias){printTokens(token,languageDefinition[parentStyle].alias)}else{that.text(token)}}else{printTokens(token.content,token.type)}}printTokens(prism.tokenize(sourceText,prism.languages[language]),"text")},true)}}}).call(this,typeof global!=="undefined"?global:typeof self!=="undefined"?self:typeof window!=="undefined"?window:{})},{"../package.json":4,prismjs:7,"prismjs/components/prism-csp.js":5,"prismjs/components/prism-graphql.js":6}],4:[function(require,module,exports){module.exports={_from:"magicpen-prism@^2.3.0",_id:"magicpen-prism@2.4.0",_inBundle:false,_integrity:"sha512-OEFZ+xksJtYgwnU5jJqDXhjvgnSFfMsSgXpJ2WWPaBJUXNKuQB0FBAiQxjRKsV5gntpg/tazH8L3apJx5eMdJg==",_location:"/magicpen-prism",_phantomChildren:{},_requested:{type:"range",registry:true,raw:"magicpen-prism@^2.3.0",name:"magicpen-prism",escapedName:"magicpen-prism",rawSpec:"^2.3.0",saveSpec:null,fetchSpec:"^2.3.0"},_requiredBy:["/"],_resolved:"https://registry.npmjs.org/magicpen-prism/-/magicpen-prism-2.4.0.tgz",_shasum:"aa79ca9b656f35069ad0aea8b102f1ac8642cbb0",_spec:"magicpen-prism@^2.3.0",_where:"/Users/ssimonsen/Code/unexpected-dom",author:{name:"Andreas Lind",email:"andreas@one.com"},bugs:{url:"https://github.com/unexpectedjs/magicpen-prism/issues"},bundleDependencies:false,dependencies:{prismjs:"1.11.0"},deprecated:false,description:"Add syntax highlighting support to magicpen via prism.js",devDependencies:{browserify:"13.0.0","bundle-collapser":"1.2.1",eslint:"2.13.1","eslint-config-onelint":"1.2.0",magicpen:"5.9.0",mocha:"2.4.5",unexpected:"10.10.5"},files:["lib","magicPenPrism.min.js"],homepage:"https://github.com/unexpectedjs/magicpen-prism#readme",main:"lib/magicPenPrism.js",name:"magicpen-prism",repository:{type:"git",url:"git+https://github.com/unexpectedjs/magicpen-prism.git"},scripts:{lint:"eslint .",prepublish:"browserify -p bundle-collapser/plugin -e lib/magicPenPrism -s magicPenPrism > magicPenPrism.min.js",test:"mocha",travis:"npm run lint && npm test"},version:"2.4.0"}},{}],5:[function(require,module,exports){Prism.languages.csp={directive:{pattern:/\b(?:(?:base-uri|form-action|frame-ancestors|plugin-types|referrer|reflected-xss|report-to|report-uri|require-sri-for|sandbox) |(?:block-all-mixed-content|disown-opener|upgrade-insecure-requests)(?: |;)|(?:child|connect|default|font|frame|img|manifest|media|object|script|style|worker)-src )/i,alias:"keyword"},safe:{pattern:/'(?:self|none|strict-dynamic|(?:nonce-|sha(?:256|384|512)-)[a-zA-Z0-9+=\/]+)'/,alias:"selector"},unsafe:{pattern:/(?:'unsafe-inline'|'unsafe-eval'|'unsafe-hashed-attributes'|\*)/,alias:"function"}}},{}],6:[function(require,module,exports){Prism.languages.graphql={comment:/#.*/,string:{pattern:/"(?:\\.|[^\\"\r\n])*"/,greedy:true},number:/(?:\B-|\b)\d+(?:\.\d+)?(?:[eE][+-]?\d+)?\b/,boolean:/\b(?:true|false)\b/,variable:/\$[a-z_]\w*/i,directive:{pattern:/@[a-z_]\w*/i,alias:"function"},"attr-name":/[a-z_]\w*(?=\s*:)/i,keyword:[{pattern:/(fragment\s+(?!on)[a-z_]\w*\s+|\.{3}\s*)on\b/,lookbehind:true},/\b(?:query|fragment|mutation)\b/],operator:/!|=|\.{3}/,punctuation:/[!(){}\[\]:=,]/}},{}],7:[function(require,module,exports){(function(global){var _self=typeof window!=="undefined"?window:typeof WorkerGlobalScope!=="undefined"&&self instanceof WorkerGlobalScope?self:{};var Prism=function(){var lang=/\blang(?:uage)?-(\w+)\b/i;var uniqueId=0;var _=_self.Prism={manual:_self.Prism&&_self.Prism.manual,disableWorkerMessageHandler:_self.Prism&&_self.Prism.disableWorkerMessageHandler,util:{encode:function(tokens){if(tokens instanceof Token){return new Token(tokens.type,_.util.encode(tokens.content),tokens.alias)}else if(_.util.type(tokens)==="Array"){return tokens.map(_.util.encode)}else{return tokens.replace(/&/g,"&").replace(/text.length){return}if(str instanceof Token){continue}pattern.lastIndex=0;var match=pattern.exec(str),delNum=1;if(!match&&greedy&&i!=strarr.length-1){pattern.lastIndex=pos;match=pattern.exec(text);if(!match){break}var from=match.index+(lookbehind?match[1].length:0),to=match.index+match[0].length,k=i,p=pos;for(var len=strarr.length;k=p){++i;pos=p}}if(strarr[i]instanceof Token||strarr[k-1].greedy){continue}delNum=k-i;str=text.slice(pos,p);match.index-=pos}if(!match){if(oneshot){break}continue}if(lookbehind){lookbehindLength=match[1].length}var from=match.index+lookbehindLength,match=match[0].slice(lookbehindLength),to=from+match.length,before=str.slice(0,from),after=str.slice(to);var args=[i,delNum];if(before){++i;pos+=before.length;args.push(before)}var wrapped=new Token(token,inside?_.tokenize(match,inside):match,alias,match,greedy);args.push(wrapped);if(after){args.push(after)}Array.prototype.splice.apply(strarr,args);if(delNum!=1)_.matchGrammar(text,strarr,grammar,i,pos,true,token);if(oneshot)break}}}},tokenize:function(text,grammar,language){var strarr=[text];var rest=grammar.rest;if(rest){for(var token in rest){grammar[token]=rest[token]}delete grammar.rest}_.matchGrammar(text,strarr,grammar,0,0,false);return strarr},hooks:{all:{},add:function(name,callback){var hooks=_.hooks.all;hooks[name]=hooks[name]||[];hooks[name].push(callback)},run:function(name,env){var callbacks=_.hooks.all[name];if(!callbacks||!callbacks.length){return}for(var i=0,callback;callback=callbacks[i++];){callback(env)}}}};var Token=_.Token=function(type,content,alias,matchedStr,greedy){this.type=type;this.content=content;this.alias=alias;this.length=(matchedStr||"").length|0;this.greedy=!!greedy};Token.stringify=function(o,language,parent){if(typeof o=="string"){return o}if(_.util.type(o)==="Array"){return o.map(function(element){return Token.stringify(element,language,o)}).join("")}var env={type:o.type,content:Token.stringify(o.content,language,parent),tag:"span",classes:["token",o.type],attributes:{},language:language,parent:parent};if(o.alias){var aliases=_.util.type(o.alias)==="Array"?o.alias:[o.alias];Array.prototype.push.apply(env.classes,aliases)}_.hooks.run("wrap",env);var attributes=Object.keys(env.attributes).map(function(name){return name+'="'+(env.attributes[name]||"").replace(/"/g,""")+'"'}).join(" ");return"<"+env.tag+' class="'+env.classes.join(" ")+'"'+(attributes?" "+attributes:"")+">"+env.content+""};if(!_self.document){if(!_self.addEventListener){return _self.Prism}if(!_.disableWorkerMessageHandler){_self.addEventListener("message",function(evt){var message=JSON.parse(evt.data),lang=message.language,code=message.code,immediateClose=message.immediateClose;_self.postMessage(_.highlight(code,_.languages[lang],lang));if(immediateClose){_self.close()}},false)}return _self.Prism}var script=document.currentScript||[].slice.call(document.getElementsByTagName("script")).pop();if(script){_.filename=script.src;if(!_.manual&&!script.hasAttribute("data-manual")){if(document.readyState!=="loading"){if(window.requestAnimationFrame){window.requestAnimationFrame(_.highlightAll)}else{window.setTimeout(_.highlightAll,16)}}else{document.addEventListener("DOMContentLoaded",_.highlightAll)}}}return _self.Prism}();if(typeof module!=="undefined"&&module.exports){module.exports=Prism}if(typeof global!=="undefined"){global.Prism=Prism}Prism.languages.markup={comment://,prolog:/<\?[\s\S]+?\?>/,doctype://i,cdata://i,tag:{pattern:/<\/?(?!\d)[^\s>\/=$<]+(?:\s+[^\s>\/=]+(?:=(?:("|')(?:\\[\s\S]|(?!\1)[^\\])*\1|[^\s'">=]+))?)*\s*\/?>/i,inside:{tag:{pattern:/^<\/?[^\s>\/]+/i,inside:{punctuation:/^<\/?/,namespace:/^[^\s>\/:]+:/}},"attr-value":{pattern:/=(?:("|')(?:\\[\s\S]|(?!\1)[^\\])*\1|[^\s'">=]+)/i,inside:{punctuation:[/^=/,{pattern:/(^|[^\\])["']/,lookbehind:true}]}},punctuation:/\/?>/,"attr-name":{pattern:/[^\s>\/]+/,inside:{namespace:/^[^\s>\/:]+:/}}}},entity:/&#?[\da-z]{1,8};/i};Prism.languages.markup["tag"].inside["attr-value"].inside["entity"]=Prism.languages.markup["entity"];Prism.hooks.add("wrap",function(env){if(env.type==="entity"){env.attributes["title"]=env.content.replace(/&/,"&")}});Prism.languages.xml=Prism.languages.markup;Prism.languages.html=Prism.languages.markup;Prism.languages.mathml=Prism.languages.markup;Prism.languages.svg=Prism.languages.markup;Prism.languages.css={comment:/\/\*[\s\S]*?\*\//,atrule:{pattern:/@[\w-]+?.*?(?:;|(?=\s*\{))/i,inside:{rule:/@[\w-]+/}},url:/url\((?:(["'])(?:\\(?:\r\n|[\s\S])|(?!\1)[^\\\r\n])*\1|.*?)\)/i,selector:/[^{}\s][^{};]*?(?=\s*\{)/,string:{pattern:/("|')(?:\\(?:\r\n|[\s\S])|(?!\1)[^\\\r\n])*\1/,greedy:true},property:/[-_a-z\xA0-\uFFFF][-\w\xA0-\uFFFF]*(?=\s*:)/i,important:/\B!important\b/i,function:/[-a-z0-9]+(?=\()/i,punctuation:/[(){};:]/};Prism.languages.css["atrule"].inside.rest=Prism.util.clone(Prism.languages.css);if(Prism.languages.markup){Prism.languages.insertBefore("markup","tag",{style:{pattern:/()[\s\S]*?(?=<\/style>)/i,lookbehind:true,inside:Prism.languages.css,alias:"language-css",greedy:true}});Prism.languages.insertBefore("inside","attr-value",{"style-attr":{pattern:/\s*style=("|')(?:\\[\s\S]|(?!\1)[^\\])*\1/i,inside:{"attr-name":{pattern:/^\s*style/i,inside:Prism.languages.markup.tag.inside},punctuation:/^\s*=\s*['"]|['"]\s*$/,"attr-value":{pattern:/.+/i,inside:Prism.languages.css}},alias:"language-css"}},Prism.languages.markup.tag)}Prism.languages.clike={comment:[{pattern:/(^|[^\\])\/\*[\s\S]*?(?:\*\/|$)/,lookbehind:true},{pattern:/(^|[^\\:])\/\/.*/,lookbehind:true}],string:{pattern:/(["'])(?:\\(?:\r\n|[\s\S])|(?!\1)[^\\\r\n])*\1/,greedy:true},"class-name":{pattern:/((?:\b(?:class|interface|extends|implements|trait|instanceof|new)\s+)|(?:catch\s+\())[\w.\\]+/i,lookbehind:true,inside:{punctuation:/[.\\]/}},keyword:/\b(?:if|else|while|do|for|return|in|instanceof|function|new|try|throw|catch|finally|null|break|continue)\b/,boolean:/\b(?:true|false)\b/,function:/[a-z0-9_]+(?=\()/i,number:/\b-?(?:0x[\da-f]+|\d*\.?\d+(?:e[+-]?\d+)?)\b/i,operator:/--?|\+\+?|!=?=?|<=?|>=?|==?=?|&&?|\|\|?|\?|\*|\/|~|\^|%/,punctuation:/[{}[\];(),.:]/};Prism.languages.javascript=Prism.languages.extend("clike",{keyword:/\b(?:as|async|await|break|case|catch|class|const|continue|debugger|default|delete|do|else|enum|export|extends|finally|for|from|function|get|if|implements|import|in|instanceof|interface|let|new|null|of|package|private|protected|public|return|set|static|super|switch|this|throw|try|typeof|var|void|while|with|yield)\b/,number:/\b-?(?:0[xX][\dA-Fa-f]+|0[bB][01]+|0[oO][0-7]+|\d*\.?\d+(?:[Ee][+-]?\d+)?|NaN|Infinity)\b/,function:/[_$a-z\xA0-\uFFFF][$\w\xA0-\uFFFF]*(?=\s*\()/i,operator:/-[-=]?|\+[+=]?|!=?=?|<>?>?=?|=(?:==?|>)?|&[&=]?|\|[|=]?|\*\*?=?|\/=?|~|\^=?|%=?|\?|\.{3}/});Prism.languages.insertBefore("javascript","keyword",{regex:{pattern:/(^|[^\/])\/(?!\/)(\[[^\]\r\n]+]|\\.|[^\/\\\[\r\n])+\/[gimyu]{0,5}(?=\s*($|[\r\n,.;})]))/,lookbehind:true,greedy:true},"function-variable":{pattern:/[_$a-z\xA0-\uFFFF][$\w\xA0-\uFFFF]*(?=\s*=\s*(?:function\b|(?:\([^()]*\)|[_$a-z\xA0-\uFFFF][$\w\xA0-\uFFFF]*)\s*=>))/i,alias:"function"}});Prism.languages.insertBefore("javascript","string",{"template-string":{pattern:/`(?:\\[\s\S]|[^\\`])*`/,greedy:true,inside:{interpolation:{pattern:/\$\{[^}]+\}/,inside:{"interpolation-punctuation":{pattern:/^\$\{|\}$/,alias:"punctuation"},rest:Prism.languages.javascript}},string:/[\s\S]+/}}});if(Prism.languages.markup){Prism.languages.insertBefore("markup","tag",{script:{pattern:/()[\s\S]*?(?=<\/script>)/i,lookbehind:true,inside:Prism.languages.javascript,alias:"language-javascript",greedy:true}})}Prism.languages.js=Prism.languages.javascript;(function(){if(typeof self==="undefined"||!self.Prism||!self.document||!document.querySelector){return}self.Prism.fileHighlight=function(){var Extensions={js:"javascript",py:"python",rb:"ruby",ps1:"powershell",psm1:"powershell",sh:"bash",bat:"batch",h:"c",tex:"latex"};Array.prototype.slice.call(document.querySelectorAll("pre[data-src]")).forEach(function(pre){var src=pre.getAttribute("data-src");var language,parent=pre;var lang=/\blang(?:uage)?-(?!\*)(\w+)\b/i;while(parent&&!lang.test(parent.className)){parent=parent.parentNode}if(parent){language=(pre.className.match(lang)||[,""])[1]}if(!language){var extension=(src.match(/\.(\w+)$/)||[,""])[1];language=Extensions[extension]||extension}var code=document.createElement("code");code.className="language-"+language;pre.textContent="";code.textContent="Loading…";pre.appendChild(code);var xhr=new XMLHttpRequest;xhr.open("GET",src,true);xhr.onreadystatechange=function(){if(xhr.readyState==4){if(xhr.status<400&&xhr.responseText){code.textContent=xhr.responseText;Prism.highlightElement(code)}else if(xhr.status>=400){code.textContent="✖ Error "+xhr.status+" while fetching file: "+xhr.statusText}else{code.textContent="✖ Error: File does not exist or is empty"}}};xhr.send(null)})};document.addEventListener("DOMContentLoaded",self.Prism.fileHighlight)})()}).call(this,typeof global!=="undefined"?global:typeof self!=="undefined"?self:typeof window!=="undefined"?window:{})},{}]},{},[1])(1)});