diff --git a/package.json b/package.json index a0574fd8..3f53b1f7 100644 --- a/package.json +++ b/package.json @@ -1,6 +1,6 @@ { "name": "unexpected-dom", - "version": "4.9.4", + "version": "4.9.5", "description": "DOM plugin for the unexpected assertion libary", "main": "lib/index.js", "files": [ diff --git a/unexpected-dom.js b/unexpected-dom.js index bb662cb0..3ecf3f36 100644 --- a/unexpected-dom.js +++ b/unexpected-dom.js @@ -83,7 +83,7 @@ function isEnumeratedAttribute(attrName) { function validateStyles(expect, str) { var invalidStyles = str.split(';').filter(function (part) { - return !/^\s*\w+\s*:\s*\w+\s*$|^$/.test(part); + return !/^\s*(\w|-)+\s*:\s*(\w|-)+\s*$|^$/.test(part); }); if (invalidStyles.length > 0) { @@ -2168,4 +2168,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;;ACziCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;AChBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;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;AACA;;AClEA;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 r(e,n,t){function o(i,f){if(!n[i]){if(!e[i]){var c=\"function\"==typeof require&&require;if(!f&&c)return c(i,!0);if(u)return u(i,!0);var a=new Error(\"Cannot find module '\"+i+\"'\");throw a.code=\"MODULE_NOT_FOUND\",a}var p=n[i]={exports:{}};e[i][0].call(p.exports,function(r){var n=e[i][1][r];return o(n||r)},p,p.exports,r,e,n,t)}return n[i].exports}for(var u=\"function\"==typeof require&&require,i=0;i<t.length;i++)o(t[i]);return o}return r})()","'use strict';\n\nvar _typeof = typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; };\n\nfunction _toConsumableArray(arr) { if (Array.isArray(arr)) { for (var i = 0, arr2 = Array(arr.length); i < arr.length; i++) { arr2[i] = arr[i]; } return arr2; } else { return Array.from(arr); } }\n\n/*global DOMParser*/\nvar matchesSelector = require('./matchesSelector');\n\nfunction getJSDOM() {\n  try {\n    return require('' + 'jsdom');\n  } catch (err) {\n    throw new Error('unexpected-dom: 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\nfunction getHtmlDocument(str) {\n  if (typeof DOMParser !== 'undefined') {\n    return new DOMParser().parseFromString(str, 'text/html');\n  } else if (typeof document !== 'undefined' && document.implementation && document.implementation.createHTMLDocument) {\n    var htmlDocument = document.implementation.createHTMLDocument('');\n    htmlDocument.open();\n    htmlDocument.write(str);\n    htmlDocument.close();\n    return htmlDocument;\n  } else {\n    var jsdom = getJSDOM();\n\n    return jsdom.JSDOM ? new jsdom.JSDOM(str).window.document : jsdom.jsdom(str);\n  }\n}\n\nfunction parseHtml(str, isFragment) {\n  if (isFragment) {\n    str = '<html><head></head><body>' + str + '</body></html>';\n  }\n  var htmlDocument = getHtmlDocument(str);\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) {\n  if (typeof DOMParser !== 'undefined') {\n    return new DOMParser().parseFromString(str, 'text/xml');\n  } else {\n    var jsdom = getJSDOM();\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\nvar matchSimpleAttribute = /^(?: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;\n\nfunction isBooleanAttribute(attrName) {\n  return matchSimpleAttribute.test(attrName);\n}\n\nfunction isEnumeratedAttribute(attrName) {\n  return attrName in enumeratedAttributeValues;\n}\n\nfunction validateStyles(expect, str) {\n  var invalidStyles = str.split(';').filter(function (part) {\n    return !/^\\s*\\w+\\s*:\\s*\\w+\\s*$|^$/.test(part);\n  });\n\n  if (invalidStyles.length > 0) {\n    expect.errorMode = 'nested';\n    expect.fail('Expectation contains invalid styles: {0}', invalidStyles.join(';'));\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    // 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  if (attributeValue === '') {\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 = node.nodeType === 9 && node.documentElement && node.implementation ? node : 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] = 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] = isHtml && isBooleanAttribute(attrs[i].name) ? true : 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).sort().forEach(function (key) {\n    result[key] = attrs[key];\n  });\n\n  return result;\n}\n\nfunction entitify(value) {\n  return String(value).replace(/&/g, '&amp;').replace(/\"/g, '&quot;').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(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).map(function (cssProp) {\n        return cssProp + ': ' + value[cssProp];\n      }).join('; ');\n    }\n    output.prismPunctuation('=\"').prismAttrValue(entitify(value)).prismPunctuation('\"');\n  }\n}\n\nfunction stringifyAttribute(attributeName, value) {\n  if (isBooleanAttribute(attributeName) || isEnumeratedAttribute(attributeName)) {\n    return attributeName;\n  } else if (attributeName === 'class') {\n    return 'class=\"' + value.join(' ') + '\"'; // FIXME: entitify\n  } else if (attributeName === 'style') {\n    return 'style=\"' + Object.keys(value)\n    // FIXME: entitify\n    .map(function (cssProp) {\n      return [cssProp, value[cssProp]].join(': ');\n    }).join('; ') + '\"';\n  } else {\n    return attributeName + '=\"' + entitify(value) + '\"';\n  }\n}\n\nfunction stringifyStartTag(element) {\n  var elementName = element.ownerDocument.contentType === 'text/html' ? element.nodeName.toLowerCase() : 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 installInto(expect) {\n    expect = expect.child();\n    expect.use(require('magicpen-prism'));\n\n    function bubbleError(body) {\n      return expect.withError(body, function (err) {\n        err.errorMode = 'bubble';\n        throw err;\n      });\n    }\n\n    expect.exportType({\n      name: 'DOMNode',\n      base: 'object',\n      identify: function identify(obj) {\n        return obj && obj.nodeName && [2, 3, 4, 5, 6, 7, 10, 11, 12].indexOf(obj.nodeType) > -1;\n      },\n      equal: function equal(a, b) {\n        return a.nodeValue === b.nodeValue;\n      },\n      inspect: function inspect(element, depth, output) {\n        return output.code(element.nodeName + ' \"' + element.nodeValue + '\"', 'prism-string');\n      }\n    });\n\n    expect.exportType({\n      name: 'DOMComment',\n      base: 'DOMNode',\n      identify: function identify(obj) {\n        return obj && typeof obj.nodeType === 'number' && obj.nodeType === 8;\n      },\n      equal: function equal(a, b) {\n        return a.nodeValue === b.nodeValue;\n      },\n      inspect: function inspect(element, depth, output) {\n        return output.code('<!--' + element.nodeValue + '-->', 'html');\n      },\n      diff: function diff(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    // Recognize <!-- ignore --> as a special subtype of DOMComment so it can be targeted by assertions:\n    expect.exportType({\n      name: 'DOMIgnoreComment',\n      base: 'DOMComment',\n      identify: function identify(obj) {\n        return this.baseType.identify(obj) && /^\\s*ignore\\s*$/.test(obj.nodeValue);\n      }\n    });\n\n    expect.exportType({\n      name: 'DOMTextNode',\n      base: 'DOMNode',\n      identify: function identify(obj) {\n        return obj && typeof obj.nodeType === 'number' && obj.nodeType === 3;\n      },\n      equal: function equal(a, b) {\n        return a.nodeValue === b.nodeValue;\n      },\n      inspect: function inspect(element, depth, output) {\n        return output.code(entitify(element.nodeValue.trim()), 'html');\n      },\n      diff: function diff(actual, expected, output, _diff2, inspect, equal) {\n        var d = _diff2(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 prefix(output) {\n        return output.text('NodeList[');\n      },\n      suffix: function suffix(output) {\n        return output.text(']');\n      },\n      similar: function similar(a, b) {\n        // Figure out whether a and b are \"struturally similar\" so they can be diffed inline.\n        return a.nodeType === 1 && b.nodeType === 1 && a.nodeName === b.nodeName;\n      },\n      identify: function identify(obj) {\n        return obj && typeof obj.length === 'number' && typeof obj.toString === 'function' && 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 || obj.constructor && obj.constructor.name === 'NodeList');\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 prefix(output) {\n        return output;\n      },\n      suffix: function suffix(output) {\n        return output;\n      },\n      delimiter: function delimiter(output) {\n        return output;\n      },\n      identify: function identify(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 identify(obj) {\n        return obj && typeof obj.nodeType === 'number' && obj.nodeType === 10 && 'publicId' in obj;\n      },\n      inspect: function inspect(doctype, depth, output, _inspect) {\n        return output.code('<!DOCTYPE ' + doctype.name + '>', 'html');\n      },\n      equal: function equal(a, b) {\n        return a.toString() === b.toString();\n      },\n      diff: function diff(actual, expected, output, _diff3) {\n        var d = _diff3('<!DOCTYPE ' + actual.name + '>', '<!DOCTYPE ' + expected.name + '>');\n        d.inline = true;\n        return d;\n      }\n    });\n\n    expect.exportType({\n      name: 'DOMDocument',\n      base: 'DOMNode',\n      identify: function identify(obj) {\n        return obj && typeof obj.nodeType === 'number' && obj.nodeType === 9 && obj.documentElement && obj.implementation;\n      },\n      inspect: function inspect(document, depth, output, _inspect2) {\n        for (var i = 0; i < document.childNodes.length; i += 1) {\n          output.append(_inspect2(document.childNodes[i]));\n        }\n        return output;\n      },\n      diff: function diff(actual, expected, output, _diff4, inspect, equal) {\n        output.inline = true;\n        output.append(_diff4(makeAttachedDOMNodeList(actual.childNodes), makeAttachedDOMNodeList(expected.childNodes)).diff);\n        return output;\n      }\n    });\n\n    expect.exportType({\n      name: 'HTMLDocument',\n      base: 'DOMDocument',\n      identify: function identify(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 identify(obj) {\n        return this.baseType.identify(obj) && /^(?:application|text)\\/xml|\\+xml\\b/.test(obj.contentType);\n      },\n      inspect: function inspect(document, depth, output, _inspect3) {\n        output.code('<?xml version=\"1.0\"?>', 'xml');\n        for (var i = 0; i < document.childNodes.length; i += 1) {\n          output.append(_inspect3(document.childNodes[i], depth - 1));\n        }\n        return output;\n      }\n    });\n\n    expect.exportType({\n      name: 'DOMDocumentFragment',\n      base: 'DOMNode',\n      identify: function identify(obj) {\n        return obj && obj.nodeType === 11; // In jsdom, documentFragment.toString() does not return [object DocumentFragment]\n      },\n      inspect: function inspect(documentFragment, depth, output, _inspect4) {\n        return output.text('DocumentFragment[').append(_inspect4(documentFragment.childNodes, depth)).text(']');\n      },\n      diff: function diff(actual, expected, output, _diff5, inspect, equal) {\n        output.inline = true;\n        output.block(_diff5(makeAttachedDOMNodeList(actual.childNodes), makeAttachedDOMNodeList(expected.childNodes)).diff);\n        return output;\n      }\n    });\n\n    expect.exportType({\n      name: 'DOMElement',\n      base: 'DOMNode',\n      identify: function identify(obj) {\n        return obj && typeof obj.nodeType === 'number' && obj.nodeType === 1 && obj.nodeName && obj.attributes;\n      },\n      equal: function equal(a, b, _equal) {\n        var aIsHtml = isInsideHtmlDocument(a);\n        var bIsHtml = isInsideHtmlDocument(b);\n        return aIsHtml === bIsHtml && (aIsHtml ? a.nodeName.toLowerCase() === b.nodeName.toLowerCase() : a.nodeName === b.nodeName) && _equal(getAttributes(a), getAttributes(b)) && _equal(a.childNodes, b.childNodes);\n      },\n      inspect: function inspect(element, depth, output, _inspect5) {\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(output.clone().code(element.textContent, type));\n            } else if (elementName === 'style') {\n              inspectedChildren.push(output.clone().code(element.textContent, element.getAttribute('type') || 'text/css'));\n            } else {\n              for (var i = 0; i < element.childNodes.length; i += 1) {\n                inspectedChildren.push(_inspect5(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.i().block(inspectedChild).nl();\n              });\n\n              output.outdentLines();\n            } else {\n              inspectedChildren.forEach(function (inspectedChild, index) {\n                return output.append(inspectedChild);\n              });\n            }\n          }\n        }\n        output.code(stringifyEndTag(element), 'html');\n        return output;\n      },\n\n      diffLimit: 512,\n      diff: function diff(actual, expected, output, _diff6, 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 = actual.childNodes.length === 0 && expected.childNodes.length === 0;\n        var conflictingElement = actual.nodeName.toLowerCase() !== expected.nodeName.toLowerCase() || !equal(getAttributes(actual), getAttributes(expected));\n\n        if (conflictingElement) {\n          var canContinueLine = true;\n          output.prismPunctuation('<').prismTag(actual.nodeName.toLowerCase());\n          if (actual.nodeName.toLowerCase() !== expected.nodeName.toLowerCase()) {\n            output.sp().annotationBlock(function (output) {\n              return output.error('should be').sp().prismTag(expected.nodeName.toLowerCase());\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(output, attributeName, actualAttributes[attributeName], isHtml);\n            if (attributeName in expectedAttributes) {\n              if (actualAttributes[attributeName] === expectedAttributes[attributeName]) {\n                canContinueLine = true;\n              } else {\n                output.sp().annotationBlock(function (output) {\n                  return output.error('should equal').sp().append(inspect(entitify(expectedAttributes[attributeName])));\n                }).nl();\n                canContinueLine = false;\n              }\n              delete expectedAttributes[attributeName];\n            } else {\n              output.sp().annotationBlock(function (output) {\n                return output.error('should be removed');\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.annotationBlock(function (output) {\n              output.error('missing').sp();\n              writeAttributeToMagicPen(output, attributeName, expectedAttributes[attributeName], isHtml);\n            }).nl();\n            canContinueLine = false;\n          });\n          output.prismPunctuation('>');\n        } else {\n          output.code(stringifyStartTag(actual), 'html');\n        }\n\n        if (!emptyElements) {\n          output.nl().indentLines().i().block(_diff6(makeAttachedDOMNodeList(actual.childNodes), makeAttachedDOMNodeList(expected.childNodes)).diff).nl().outdentLines();\n        }\n\n        output.code(stringifyEndTag(actual), 'html');\n        return output;\n      }\n    });\n\n    expect.exportAssertion('<DOMElement> to have (class|classes) <array|string>', function (expect, subject, value) {\n      return expect(subject, 'to have attributes', { class: value });\n    });\n\n    expect.exportAssertion('<DOMElement> to only have (class|classes) <array|string>', function (expect, subject, value) {\n      return expect(subject, 'to have attributes', {\n        class: function _class(className) {\n          var actualClasses = getClassNamesFromAttributeValue(className);\n          if (typeof value === 'string') {\n            value = getClassNamesFromAttributeValue(value);\n          }\n          return bubbleError(function () {\n            return expect(actualClasses.sort(), 'to equal', value.sort());\n          });\n        }\n      });\n    });\n\n    expect.exportAssertion('<DOMTextNode> to [exhaustively] satisfy <DOMTextNode>', function (expect, subject, value) {\n      return expect(subject.nodeValue, 'to equal', value.nodeValue);\n    });\n\n    expect.exportAssertion('<DOMComment> to [exhaustively] satisfy <DOMComment>', function (expect, subject, value) {\n      return expect(subject.nodeValue, 'to equal', value.nodeValue);\n    });\n\n    // Avoid rendering a huge object diff when a text node is matched against a different node type:\n    expect.exportAssertion('<DOMTextNode> to [exhaustively] satisfy <object>', function (expect, subject, value) {\n      return expect.fail();\n    });\n\n    // Always passes:\n    expect.exportAssertion(\n    // Name each subject type to increase the specificity of the assertion\n    '<DOMComment|DOMElement|DOMTextNode|DOMDocument|HTMLDocType> to [exhaustively] satisfy <DOMIgnoreComment>', function (expect, subject, value) {});\n\n    // Necessary because this case would otherwise be handled by the above catch-all for <object>:\n    expect.exportAssertion('<DOMTextNode> to [exhaustively] satisfy <regexp>', function (expect, _ref, value) {\n      var nodeValue = _ref.nodeValue;\n      return expect(nodeValue, 'to satisfy', value);\n    });\n\n    expect.exportAssertion('<DOMTextNode> to [exhaustively] satisfy <any>', function (expect, _ref2, value) {\n      var nodeValue = _ref2.nodeValue;\n      return expect(nodeValue, 'to satisfy', value);\n    });\n\n    function convertDOMNodeToSatisfySpec(node, isHtml) {\n      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        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] = isHtml && isBooleanAttribute(node.attributes[i].name) ? true : node.attributes[i].value || '';\n          }\n        }\n        result.children = Array.prototype.map.call(node.childNodes, function (childNode) {\n          return convertDOMNodeToSatisfySpec(childNode, isHtml);\n        });\n        return result;\n      } else if (node.nodeType === 3) {\n        // DOMTextNode\n        return node.nodeValue;\n      } else if (node.nodeType === 8) {\n        // DOMComment\n        return node;\n      } else {\n        throw new Error('to satisfy: Node type ' + node.nodeType + ' is not yet supported in the value');\n      }\n    }\n\n    expect.exportAssertion('<DOMNodeList> to [exhaustively] satisfy <string>', function (expect, subject, value) {\n      var isHtml = subject.ownerDocument.contentType === 'text/html';\n\n      expect.argsOutput = function (output) {\n        return output.code(value, isHtml ? 'html' : 'xml');\n      };\n\n      return expect(subject, 'to [exhaustively] satisfy', (isHtml ? parseHtml(value, true) : parseXml(value)).childNodes);\n    });\n\n    expect.exportAssertion('<DOMNodeList> to [exhaustively] satisfy <DOMNodeList>', 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    expect.exportAssertion('<DOMDocumentFragment> to [exhaustively] satisfy <string>', function (expect, subject, value) {\n      var isHtml = isInsideHtmlDocument(subject);\n\n      expect.argsOutput = function (output) {\n        return output.code(value, isHtml ? 'html' : 'xml');\n      };\n\n      return expect(subject, 'to [exhaustively] satisfy', isHtml ? parseHtml(value, true) : parseXml(value));\n    });\n\n    expect.exportAssertion('<DOMDocumentFragment> to [exhaustively] satisfy <DOMDocumentFragment>', function (expect, subject, _ref3) {\n      var childNodes = _ref3.childNodes;\n\n      var isHtml = subject.ownerDocument.contentType === 'text/html';\n      return expect(subject, 'to [exhaustively] satisfy', Array.prototype.map.call(childNodes, function (childNode) {\n        return convertDOMNodeToSatisfySpec(childNode, isHtml);\n      }));\n    });\n\n    expect.exportAssertion('<DOMDocumentFragment> to [exhaustively] satisfy <object|array>', function (expect, _ref4, value) {\n      var childNodes = _ref4.childNodes;\n      return expect(childNodes, 'to [exhaustively] satisfy', value);\n    });\n\n    expect.exportAssertion('<DOMElement> to [exhaustively] satisfy <string>', function (expect, subject, value) {\n      var isHtml = isInsideHtmlDocument(subject);\n      var documentFragment = isHtml ? parseHtml(value, true) : parseXml(value);\n      if (documentFragment.childNodes.length !== 1) {\n        throw new Error('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\n      return expect(subject, 'to [exhaustively] satisfy', documentFragment.childNodes[0]);\n    });\n\n    expect.exportAssertion('<DOMDocument> to [exhaustively] satisfy <string>', function (expect, subject, value) {\n      var isHtml = isInsideHtmlDocument(subject);\n      var valueDocument = isHtml ? parseHtml(value, false) : parseXml(value);\n      return expect(makeAttachedDOMNodeList(subject.childNodes), 'to [exhaustively] satisfy', Array.prototype.map.call(valueDocument.childNodes, function (childNode) {\n        return convertDOMNodeToSatisfySpec(childNode, isHtml);\n      }));\n    });\n\n    expect.exportAssertion('<DOMDocument> to [exhaustively] satisfy <DOMDocument>', function (expect, subject, _ref5) {\n      var childNodes = _ref5.childNodes;\n\n      var isHtml = isInsideHtmlDocument(subject);\n      return expect(makeAttachedDOMNodeList(subject.childNodes), 'to [exhaustively] satisfy', Array.prototype.map.call(childNodes, function (childNode) {\n        return convertDOMNodeToSatisfySpec(childNode, isHtml);\n      }));\n    });\n\n    expect.exportAssertion('<DOMElement> to [exhaustively] satisfy <DOMElement>', function (expect, subject, value) {\n      return expect(subject, 'to [exhaustively] satisfy', convertDOMNodeToSatisfySpec(value, isInsideHtmlDocument(subject)));\n    });\n\n    expect.exportAssertion(['<DOMElement> to [exhaustively] satisfy <DOMTextNode>', '<DOMTextNode> to [exhaustively] satisfy <DOMElement>', '<DOMElement|DOMDocumentFragment|DOMDocument> to [exhaustively] satisfy <regexp>'], function (expect, subject, value) {\n      return expect.fail();\n    });\n\n    expect.exportAssertion('<DOMElement> to [exhaustively] satisfy <object>', function (expect, subject, value) {\n      var isHtml = isInsideHtmlDocument(subject);\n      var unsupportedOptions = Object.keys(value).filter(function (key) {\n        return key !== 'attributes' && key !== 'name' && key !== 'children' && key !== 'onlyAttributes' && key !== 'textContent';\n      });\n      if (unsupportedOptions.length > 0) {\n        throw new Error('Unsupported option' + (unsupportedOptions.length === 1 ? '' : 's') + ': ' + unsupportedOptions.join(', '));\n      }\n\n      var promiseByKey = {\n        name: expect.promise(function () {\n          if (value && typeof value.name !== 'undefined') {\n            return bubbleError(function () {\n              return expect(isHtml ? subject.nodeName.toLowerCase() : subject.nodeName, 'to satisfy', 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('The children and textContent properties are not supported together');\n            }\n            return bubbleError(function () {\n              return expect(makeAttachedDOMNodeList(subject.childNodes, subject.ownerDocument.contentType), 'to satisfy', value.children);\n            });\n          } else if (typeof value.textContent !== 'undefined') {\n            return bubbleError(function () {\n              return expect(subject.textContent, 'to satisfy', value.textContent);\n            });\n          }\n        }),\n        attributes: {}\n      };\n\n      var onlyAttributes = value && value.onlyAttributes || expect.flags.exhaustively;\n      var attrs = getAttributes(subject);\n      var expectedAttributes = value && value.attributes;\n      var expectedAttributeNames = [];\n      var expectedValueByAttributeName = {};\n\n      if (typeof expectedAttributes !== 'undefined') {\n        if (typeof expectedAttributes === 'string') {\n          expectedAttributes = [expectedAttributes];\n        }\n        if (Array.isArray(expectedAttributes)) {\n          expectedAttributes.forEach(function (attributeName) {\n            expectedValueByAttributeName[attributeName] = true;\n          });\n        } else if (expectedAttributes && (typeof expectedAttributes === 'undefined' ? 'undefined' : _typeof(expectedAttributes)) === 'object') {\n          expectedValueByAttributeName = expectedAttributes;\n        }\n        Object.keys(expectedValueByAttributeName).forEach(function (attributeName) {\n          expectedAttributeNames.push(attributeName);\n        });\n\n        expectedAttributeNames.forEach(function (attributeName) {\n          var attributeValue = subject.getAttribute(attributeName);\n          var expectedAttributeValue = expectedValueByAttributeName[attributeName];\n          promiseByKey.attributes[attributeName] = expect.promise(function () {\n            if (typeof expectedAttributeValue === 'undefined') {\n              return bubbleError(function () {\n                return expect(subject.hasAttribute(attributeName), 'to be false');\n              });\n            } else if (isEnumeratedAttribute(attributeName)) {\n              var indexOfEnumeratedAttributeValue = enumeratedAttributeValues[attributeName].indexOf(expectedAttributeValue);\n\n              return bubbleError(function () {\n                if (indexOfEnumeratedAttributeValue === -1) {\n                  expect.fail(function (output) {\n                    return output.text('Invalid expected value ').appendInspected(expectedAttributeValue).text('. Supported values include: ').appendItems(enumeratedAttributeValues[attributeName], ', ');\n                  });\n                }\n\n                expect(attributeValue, 'to satisfy', expectedAttributeValue);\n              });\n            } else if (expectedAttributeValue === true) {\n              return bubbleError(function () {\n                return expect(subject.hasAttribute(attributeName), 'to be true');\n              });\n            } else if (attributeName === 'class' && (typeof expectedAttributeValue === 'string' || Array.isArray(expectedAttributeValue))) {\n              var actualClasses = getClassNamesFromAttributeValue(attributeValue);\n              var expectedClasses = expectedAttributeValue;\n              if (typeof expectedClasses === 'string') {\n                expectedClasses = getClassNamesFromAttributeValue(expectedAttributeValue);\n              }\n              if (onlyAttributes) {\n                return bubbleError(function () {\n                  return expect(actualClasses.sort(), 'to equal', expectedClasses.sort());\n                });\n              } else {\n                if (expectedClasses.length === 0) {\n                  return bubbleError(function () {\n                    return expect(expectedClasses, 'to be empty');\n                  });\n                }\n                return bubbleError(function () {\n                  return expect.apply(undefined, [actualClasses, 'to contain'].concat(_toConsumableArray(expectedClasses)));\n                });\n              }\n            } else if (attributeName === 'style') {\n              var expectedStyleObj = void 0;\n              if (typeof expectedValueByAttributeName.style === 'string') {\n                validateStyles(expect, expectedValueByAttributeName.style);\n                expectedStyleObj = styleStringToObject(expectedValueByAttributeName.style);\n              } else {\n                expectedStyleObj = expectedValueByAttributeName.style;\n              }\n\n              if (onlyAttributes) {\n                return bubbleError(function () {\n                  return expect(attrs.style, 'to exhaustively satisfy', expectedStyleObj);\n                });\n              } else {\n                return bubbleError(function () {\n                  return expect(attrs.style, 'to satisfy', expectedStyleObj);\n                });\n              }\n            } else {\n              return bubbleError(function () {\n                return expect(attributeValue, 'to satisfy', expectedAttributeValue);\n              });\n            }\n          });\n        });\n\n        promiseByKey.attributePresence = expect.promise(function () {\n          var attributeNamesExpectedToBeDefined = [];\n          expectedAttributeNames.forEach(function (attributeName) {\n            if (typeof expectedValueByAttributeName[attributeName] === 'undefined') {\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(Object.keys(attrs).sort(), 'to equal', attributeNamesExpectedToBeDefined.sort());\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 diff(output, _diff7, inspect, equal) {\n              output.block(function (output) {\n                var seenError = false;\n                output.prismPunctuation('<').prismTag(isHtml ? subject.nodeName.toLowerCase() : subject.nodeName);\n                if (promiseByKey.name.isRejected()) {\n                  seenError = true;\n                  var nameError = promiseByKey.name.reason();\n                  output.sp().annotationBlock(function (output) {\n                    return output.error(nameError && nameError.getLabel() || 'should satisfy').sp().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(attributeOutput, attributeName, attrs[attributeName], isHtml);\n                  if (promise && promise.isFulfilled() || !promise && (!onlyAttributes || expectedAttributeNames.indexOf(attributeName) !== -1)) {} else {\n                    seenError = true;\n                    attributeOutput.sp().annotationBlock(function (output) {\n                      if (promise && typeof expectedValueByAttributeName[attributeName] !== 'undefined') {\n                        output.appendErrorMessage(promise.reason());\n                      } else {\n                        // onlyAttributes === true\n                        output.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.clone().annotationBlock(function (output) {\n                        output.error('missing').sp().prismAttrName(attributeName, 'html');\n                        if (expectedValueByAttributeName[attributeName] !== true) {\n                          output.sp().error(err && err.getLabel() || 'should satisfy').sp().append(inspect(expectedValueByAttributeName[attributeName]));\n                        }\n                      });\n                      inspectedAttributes.push(attributeOutput);\n                    }\n                  }\n                });\n                if (inspectedAttributes.length > 0) {\n                  if (seenError) {\n                    output.nl().indentLines().indent().block(function (output) {\n                      inspectedAttributes.forEach(function (item, i) {\n                        if (i > 0) {\n                          output.nl();\n                        }\n                        output.append(item);\n                      });\n                    }).outdentLines().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 = promiseByKey.children.isRejected() && promiseByKey.children.reason();\n                if (childrenError) {\n                  var childrenDiff = childrenError.getDiff(output);\n                  if (childrenDiff && childrenDiff.inline) {\n                    output.nl().indentLines().i().block(childrenDiff.diff).nl().outdentLines();\n                  } else {\n                    output.nl().indentLines().i().block(function (output) {\n                      for (var i = 0; i < subject.childNodes.length; i += 1) {\n                        output.append(inspect(subject.childNodes[i])).nl();\n                      }\n                    });\n                    output.sp().annotationBlock(function (output) {\n                      return output.appendErrorMessage(childrenError);\n                    });\n                    output.nl();\n                  }\n                } else {\n                  for (var i = 0; i < subject.childNodes.length; i += 1) {\n                    output.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    expect.exportAssertion('<DOMElement> to [only] have (attribute|attributes) <string+>', function (expect, subject) {\n      for (var _len = arguments.length, args = Array(_len > 2 ? _len - 2 : 0), _key = 2; _key < _len; _key++) {\n        args[_key - 2] = arguments[_key];\n      }\n\n      return expect(subject, 'to [only] have attributes', args);\n    });\n\n    expect.exportAssertion('<DOMElement> not to have (attribute|attributes) <array>', 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    expect.exportAssertion('<DOMElement> not to have (attribute|attributes) <string+>', function (expect, subject) {\n      for (var _len2 = arguments.length, args = Array(_len2 > 2 ? _len2 - 2 : 0), _key2 = 2; _key2 < _len2; _key2++) {\n        args[_key2 - 2] = arguments[_key2];\n      }\n\n      return expect(subject, 'not to have attributes', args);\n    });\n\n    expect.exportAssertion('<DOMElement> to [only] have (attribute|attributes) <array|object>', function (expect, subject, value) {\n      return expect(subject, 'to satisfy', {\n        attributes: value,\n        onlyAttributes: expect.flags.only\n      });\n    });\n\n    expect.exportAssertion('<DOMElement> to have [no] (child|children)', function (expect, _ref6) {\n      var childNodes = _ref6.childNodes;\n      return expect.flags.no ? expect(childNodes, 'to be empty') : expect(childNodes, 'not to be empty');\n    });\n\n    expect.exportAssertion('<DOMElement> to have text <any>', function (expect, _ref7, value) {\n      var textContent = _ref7.textContent;\n      return expect(textContent, 'to satisfy', value);\n    });\n\n    expect.exportAssertion('<DOMDocument|DOMElement|DOMDocumentFragment> [when] queried for [first] <string> <assertion?>', function (expect, subject, query) {\n      var queryResult = void 0;\n\n      expect.argsOutput[0] = function (output) {\n        return output.green(query);\n      };\n      expect.errorMode = 'nested';\n\n      if (expect.flags.first) {\n        queryResult = subject.querySelector(query);\n        if (!queryResult) {\n          expect.subjectOutput = function (output) {\n            return expect.inspect(subject, Infinity, output);\n          };\n\n          expect.fail(function (output) {\n            return output.error('The selector').sp().jsString(query).sp().error('yielded no results');\n          });\n        }\n      } else {\n        queryResult = subject.querySelectorAll(query);\n        if (queryResult.length === 0) {\n          expect.subjectOutput = function (output) {\n            return expect.inspect(subject, Infinity, output);\n          };\n\n          expect.fail(function (output) {\n            return output.error('The selector').sp().jsString(query).sp().error('yielded no results');\n          });\n        }\n      }\n      return expect.shift(queryResult);\n    });\n\n    expect.exportAssertion('<DOMDocument|DOMElement|DOMDocumentFragment> to contain [no] elements matching <string>', 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        return expect.inspect(subject, Infinity, output);\n      };\n\n      return expect(subject.querySelectorAll(query), 'not to satisfy', []);\n    });\n\n    expect.exportAssertion('<DOMDocument|DOMElement|DOMDocumentFragment> [not] to match <string>', function (expect, subject, query) {\n      expect.subjectOutput = function (output) {\n        return expect.inspect(subject, Infinity, output);\n      };\n\n      return expect(matchesSelector(subject, query), '[not] to be true');\n    });\n\n    expect.exportAssertion('<string> [when] parsed as (html|HTML) [fragment] <assertion?>', function (expect, subject) {\n      expect.errorMode = 'nested';\n      return expect.shift(parseHtml(subject, expect.flags.fragment));\n    });\n\n    expect.exportAssertion('<string> [when] parsed as (xml|XML) <assertion?>', function (expect, subject) {\n      expect.errorMode = 'nested';\n      return expect.shift(parseXml(subject));\n    });\n  }\n};","\"use strict\";\n\nmodule.exports = function (elm, selector) {\n  var matchFuntion = elm.matchesSelector || elm.mozMatchesSelector || elm.msMatchesSelector || elm.oMatchesSelector || elm.webkitMatchesSelector || 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};","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    \"/unexpected-markdown\"\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;;ACziCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;AChBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;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;AACA;;AClEA;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 r(e,n,t){function o(i,f){if(!n[i]){if(!e[i]){var c=\"function\"==typeof require&&require;if(!f&&c)return c(i,!0);if(u)return u(i,!0);var a=new Error(\"Cannot find module '\"+i+\"'\");throw a.code=\"MODULE_NOT_FOUND\",a}var p=n[i]={exports:{}};e[i][0].call(p.exports,function(r){var n=e[i][1][r];return o(n||r)},p,p.exports,r,e,n,t)}return n[i].exports}for(var u=\"function\"==typeof require&&require,i=0;i<t.length;i++)o(t[i]);return o}return r})()","'use strict';\n\nvar _typeof = typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; };\n\nfunction _toConsumableArray(arr) { if (Array.isArray(arr)) { for (var i = 0, arr2 = Array(arr.length); i < arr.length; i++) { arr2[i] = arr[i]; } return arr2; } else { return Array.from(arr); } }\n\n/*global DOMParser*/\nvar matchesSelector = require('./matchesSelector');\n\nfunction getJSDOM() {\n  try {\n    return require('' + 'jsdom');\n  } catch (err) {\n    throw new Error('unexpected-dom: 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\nfunction getHtmlDocument(str) {\n  if (typeof DOMParser !== 'undefined') {\n    return new DOMParser().parseFromString(str, 'text/html');\n  } else if (typeof document !== 'undefined' && document.implementation && document.implementation.createHTMLDocument) {\n    var htmlDocument = document.implementation.createHTMLDocument('');\n    htmlDocument.open();\n    htmlDocument.write(str);\n    htmlDocument.close();\n    return htmlDocument;\n  } else {\n    var jsdom = getJSDOM();\n\n    return jsdom.JSDOM ? new jsdom.JSDOM(str).window.document : jsdom.jsdom(str);\n  }\n}\n\nfunction parseHtml(str, isFragment) {\n  if (isFragment) {\n    str = '<html><head></head><body>' + str + '</body></html>';\n  }\n  var htmlDocument = getHtmlDocument(str);\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) {\n  if (typeof DOMParser !== 'undefined') {\n    return new DOMParser().parseFromString(str, 'text/xml');\n  } else {\n    var jsdom = getJSDOM();\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\nvar matchSimpleAttribute = /^(?: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;\n\nfunction isBooleanAttribute(attrName) {\n  return matchSimpleAttribute.test(attrName);\n}\n\nfunction isEnumeratedAttribute(attrName) {\n  return attrName in enumeratedAttributeValues;\n}\n\nfunction validateStyles(expect, str) {\n  var invalidStyles = str.split(';').filter(function (part) {\n    return !/^\\s*(\\w|-)+\\s*:\\s*(\\w|-)+\\s*$|^$/.test(part);\n  });\n\n  if (invalidStyles.length > 0) {\n    expect.errorMode = 'nested';\n    expect.fail('Expectation contains invalid styles: {0}', invalidStyles.join(';'));\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    // 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  if (attributeValue === '') {\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 = node.nodeType === 9 && node.documentElement && node.implementation ? node : 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] = 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] = isHtml && isBooleanAttribute(attrs[i].name) ? true : 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).sort().forEach(function (key) {\n    result[key] = attrs[key];\n  });\n\n  return result;\n}\n\nfunction entitify(value) {\n  return String(value).replace(/&/g, '&amp;').replace(/\"/g, '&quot;').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(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).map(function (cssProp) {\n        return cssProp + ': ' + value[cssProp];\n      }).join('; ');\n    }\n    output.prismPunctuation('=\"').prismAttrValue(entitify(value)).prismPunctuation('\"');\n  }\n}\n\nfunction stringifyAttribute(attributeName, value) {\n  if (isBooleanAttribute(attributeName) || isEnumeratedAttribute(attributeName)) {\n    return attributeName;\n  } else if (attributeName === 'class') {\n    return 'class=\"' + value.join(' ') + '\"'; // FIXME: entitify\n  } else if (attributeName === 'style') {\n    return 'style=\"' + Object.keys(value)\n    // FIXME: entitify\n    .map(function (cssProp) {\n      return [cssProp, value[cssProp]].join(': ');\n    }).join('; ') + '\"';\n  } else {\n    return attributeName + '=\"' + entitify(value) + '\"';\n  }\n}\n\nfunction stringifyStartTag(element) {\n  var elementName = element.ownerDocument.contentType === 'text/html' ? element.nodeName.toLowerCase() : 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 installInto(expect) {\n    expect = expect.child();\n    expect.use(require('magicpen-prism'));\n\n    function bubbleError(body) {\n      return expect.withError(body, function (err) {\n        err.errorMode = 'bubble';\n        throw err;\n      });\n    }\n\n    expect.exportType({\n      name: 'DOMNode',\n      base: 'object',\n      identify: function identify(obj) {\n        return obj && obj.nodeName && [2, 3, 4, 5, 6, 7, 10, 11, 12].indexOf(obj.nodeType) > -1;\n      },\n      equal: function equal(a, b) {\n        return a.nodeValue === b.nodeValue;\n      },\n      inspect: function inspect(element, depth, output) {\n        return output.code(element.nodeName + ' \"' + element.nodeValue + '\"', 'prism-string');\n      }\n    });\n\n    expect.exportType({\n      name: 'DOMComment',\n      base: 'DOMNode',\n      identify: function identify(obj) {\n        return obj && typeof obj.nodeType === 'number' && obj.nodeType === 8;\n      },\n      equal: function equal(a, b) {\n        return a.nodeValue === b.nodeValue;\n      },\n      inspect: function inspect(element, depth, output) {\n        return output.code('<!--' + element.nodeValue + '-->', 'html');\n      },\n      diff: function diff(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    // Recognize <!-- ignore --> as a special subtype of DOMComment so it can be targeted by assertions:\n    expect.exportType({\n      name: 'DOMIgnoreComment',\n      base: 'DOMComment',\n      identify: function identify(obj) {\n        return this.baseType.identify(obj) && /^\\s*ignore\\s*$/.test(obj.nodeValue);\n      }\n    });\n\n    expect.exportType({\n      name: 'DOMTextNode',\n      base: 'DOMNode',\n      identify: function identify(obj) {\n        return obj && typeof obj.nodeType === 'number' && obj.nodeType === 3;\n      },\n      equal: function equal(a, b) {\n        return a.nodeValue === b.nodeValue;\n      },\n      inspect: function inspect(element, depth, output) {\n        return output.code(entitify(element.nodeValue.trim()), 'html');\n      },\n      diff: function diff(actual, expected, output, _diff2, inspect, equal) {\n        var d = _diff2(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 prefix(output) {\n        return output.text('NodeList[');\n      },\n      suffix: function suffix(output) {\n        return output.text(']');\n      },\n      similar: function similar(a, b) {\n        // Figure out whether a and b are \"struturally similar\" so they can be diffed inline.\n        return a.nodeType === 1 && b.nodeType === 1 && a.nodeName === b.nodeName;\n      },\n      identify: function identify(obj) {\n        return obj && typeof obj.length === 'number' && typeof obj.toString === 'function' && 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 || obj.constructor && obj.constructor.name === 'NodeList');\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 prefix(output) {\n        return output;\n      },\n      suffix: function suffix(output) {\n        return output;\n      },\n      delimiter: function delimiter(output) {\n        return output;\n      },\n      identify: function identify(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 identify(obj) {\n        return obj && typeof obj.nodeType === 'number' && obj.nodeType === 10 && 'publicId' in obj;\n      },\n      inspect: function inspect(doctype, depth, output, _inspect) {\n        return output.code('<!DOCTYPE ' + doctype.name + '>', 'html');\n      },\n      equal: function equal(a, b) {\n        return a.toString() === b.toString();\n      },\n      diff: function diff(actual, expected, output, _diff3) {\n        var d = _diff3('<!DOCTYPE ' + actual.name + '>', '<!DOCTYPE ' + expected.name + '>');\n        d.inline = true;\n        return d;\n      }\n    });\n\n    expect.exportType({\n      name: 'DOMDocument',\n      base: 'DOMNode',\n      identify: function identify(obj) {\n        return obj && typeof obj.nodeType === 'number' && obj.nodeType === 9 && obj.documentElement && obj.implementation;\n      },\n      inspect: function inspect(document, depth, output, _inspect2) {\n        for (var i = 0; i < document.childNodes.length; i += 1) {\n          output.append(_inspect2(document.childNodes[i]));\n        }\n        return output;\n      },\n      diff: function diff(actual, expected, output, _diff4, inspect, equal) {\n        output.inline = true;\n        output.append(_diff4(makeAttachedDOMNodeList(actual.childNodes), makeAttachedDOMNodeList(expected.childNodes)).diff);\n        return output;\n      }\n    });\n\n    expect.exportType({\n      name: 'HTMLDocument',\n      base: 'DOMDocument',\n      identify: function identify(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 identify(obj) {\n        return this.baseType.identify(obj) && /^(?:application|text)\\/xml|\\+xml\\b/.test(obj.contentType);\n      },\n      inspect: function inspect(document, depth, output, _inspect3) {\n        output.code('<?xml version=\"1.0\"?>', 'xml');\n        for (var i = 0; i < document.childNodes.length; i += 1) {\n          output.append(_inspect3(document.childNodes[i], depth - 1));\n        }\n        return output;\n      }\n    });\n\n    expect.exportType({\n      name: 'DOMDocumentFragment',\n      base: 'DOMNode',\n      identify: function identify(obj) {\n        return obj && obj.nodeType === 11; // In jsdom, documentFragment.toString() does not return [object DocumentFragment]\n      },\n      inspect: function inspect(documentFragment, depth, output, _inspect4) {\n        return output.text('DocumentFragment[').append(_inspect4(documentFragment.childNodes, depth)).text(']');\n      },\n      diff: function diff(actual, expected, output, _diff5, inspect, equal) {\n        output.inline = true;\n        output.block(_diff5(makeAttachedDOMNodeList(actual.childNodes), makeAttachedDOMNodeList(expected.childNodes)).diff);\n        return output;\n      }\n    });\n\n    expect.exportType({\n      name: 'DOMElement',\n      base: 'DOMNode',\n      identify: function identify(obj) {\n        return obj && typeof obj.nodeType === 'number' && obj.nodeType === 1 && obj.nodeName && obj.attributes;\n      },\n      equal: function equal(a, b, _equal) {\n        var aIsHtml = isInsideHtmlDocument(a);\n        var bIsHtml = isInsideHtmlDocument(b);\n        return aIsHtml === bIsHtml && (aIsHtml ? a.nodeName.toLowerCase() === b.nodeName.toLowerCase() : a.nodeName === b.nodeName) && _equal(getAttributes(a), getAttributes(b)) && _equal(a.childNodes, b.childNodes);\n      },\n      inspect: function inspect(element, depth, output, _inspect5) {\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(output.clone().code(element.textContent, type));\n            } else if (elementName === 'style') {\n              inspectedChildren.push(output.clone().code(element.textContent, element.getAttribute('type') || 'text/css'));\n            } else {\n              for (var i = 0; i < element.childNodes.length; i += 1) {\n                inspectedChildren.push(_inspect5(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.i().block(inspectedChild).nl();\n              });\n\n              output.outdentLines();\n            } else {\n              inspectedChildren.forEach(function (inspectedChild, index) {\n                return output.append(inspectedChild);\n              });\n            }\n          }\n        }\n        output.code(stringifyEndTag(element), 'html');\n        return output;\n      },\n\n      diffLimit: 512,\n      diff: function diff(actual, expected, output, _diff6, 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 = actual.childNodes.length === 0 && expected.childNodes.length === 0;\n        var conflictingElement = actual.nodeName.toLowerCase() !== expected.nodeName.toLowerCase() || !equal(getAttributes(actual), getAttributes(expected));\n\n        if (conflictingElement) {\n          var canContinueLine = true;\n          output.prismPunctuation('<').prismTag(actual.nodeName.toLowerCase());\n          if (actual.nodeName.toLowerCase() !== expected.nodeName.toLowerCase()) {\n            output.sp().annotationBlock(function (output) {\n              return output.error('should be').sp().prismTag(expected.nodeName.toLowerCase());\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(output, attributeName, actualAttributes[attributeName], isHtml);\n            if (attributeName in expectedAttributes) {\n              if (actualAttributes[attributeName] === expectedAttributes[attributeName]) {\n                canContinueLine = true;\n              } else {\n                output.sp().annotationBlock(function (output) {\n                  return output.error('should equal').sp().append(inspect(entitify(expectedAttributes[attributeName])));\n                }).nl();\n                canContinueLine = false;\n              }\n              delete expectedAttributes[attributeName];\n            } else {\n              output.sp().annotationBlock(function (output) {\n                return output.error('should be removed');\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.annotationBlock(function (output) {\n              output.error('missing').sp();\n              writeAttributeToMagicPen(output, attributeName, expectedAttributes[attributeName], isHtml);\n            }).nl();\n            canContinueLine = false;\n          });\n          output.prismPunctuation('>');\n        } else {\n          output.code(stringifyStartTag(actual), 'html');\n        }\n\n        if (!emptyElements) {\n          output.nl().indentLines().i().block(_diff6(makeAttachedDOMNodeList(actual.childNodes), makeAttachedDOMNodeList(expected.childNodes)).diff).nl().outdentLines();\n        }\n\n        output.code(stringifyEndTag(actual), 'html');\n        return output;\n      }\n    });\n\n    expect.exportAssertion('<DOMElement> to have (class|classes) <array|string>', function (expect, subject, value) {\n      return expect(subject, 'to have attributes', { class: value });\n    });\n\n    expect.exportAssertion('<DOMElement> to only have (class|classes) <array|string>', function (expect, subject, value) {\n      return expect(subject, 'to have attributes', {\n        class: function _class(className) {\n          var actualClasses = getClassNamesFromAttributeValue(className);\n          if (typeof value === 'string') {\n            value = getClassNamesFromAttributeValue(value);\n          }\n          return bubbleError(function () {\n            return expect(actualClasses.sort(), 'to equal', value.sort());\n          });\n        }\n      });\n    });\n\n    expect.exportAssertion('<DOMTextNode> to [exhaustively] satisfy <DOMTextNode>', function (expect, subject, value) {\n      return expect(subject.nodeValue, 'to equal', value.nodeValue);\n    });\n\n    expect.exportAssertion('<DOMComment> to [exhaustively] satisfy <DOMComment>', function (expect, subject, value) {\n      return expect(subject.nodeValue, 'to equal', value.nodeValue);\n    });\n\n    // Avoid rendering a huge object diff when a text node is matched against a different node type:\n    expect.exportAssertion('<DOMTextNode> to [exhaustively] satisfy <object>', function (expect, subject, value) {\n      return expect.fail();\n    });\n\n    // Always passes:\n    expect.exportAssertion(\n    // Name each subject type to increase the specificity of the assertion\n    '<DOMComment|DOMElement|DOMTextNode|DOMDocument|HTMLDocType> to [exhaustively] satisfy <DOMIgnoreComment>', function (expect, subject, value) {});\n\n    // Necessary because this case would otherwise be handled by the above catch-all for <object>:\n    expect.exportAssertion('<DOMTextNode> to [exhaustively] satisfy <regexp>', function (expect, _ref, value) {\n      var nodeValue = _ref.nodeValue;\n      return expect(nodeValue, 'to satisfy', value);\n    });\n\n    expect.exportAssertion('<DOMTextNode> to [exhaustively] satisfy <any>', function (expect, _ref2, value) {\n      var nodeValue = _ref2.nodeValue;\n      return expect(nodeValue, 'to satisfy', value);\n    });\n\n    function convertDOMNodeToSatisfySpec(node, isHtml) {\n      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        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] = isHtml && isBooleanAttribute(node.attributes[i].name) ? true : node.attributes[i].value || '';\n          }\n        }\n        result.children = Array.prototype.map.call(node.childNodes, function (childNode) {\n          return convertDOMNodeToSatisfySpec(childNode, isHtml);\n        });\n        return result;\n      } else if (node.nodeType === 3) {\n        // DOMTextNode\n        return node.nodeValue;\n      } else if (node.nodeType === 8) {\n        // DOMComment\n        return node;\n      } else {\n        throw new Error('to satisfy: Node type ' + node.nodeType + ' is not yet supported in the value');\n      }\n    }\n\n    expect.exportAssertion('<DOMNodeList> to [exhaustively] satisfy <string>', function (expect, subject, value) {\n      var isHtml = subject.ownerDocument.contentType === 'text/html';\n\n      expect.argsOutput = function (output) {\n        return output.code(value, isHtml ? 'html' : 'xml');\n      };\n\n      return expect(subject, 'to [exhaustively] satisfy', (isHtml ? parseHtml(value, true) : parseXml(value)).childNodes);\n    });\n\n    expect.exportAssertion('<DOMNodeList> to [exhaustively] satisfy <DOMNodeList>', 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    expect.exportAssertion('<DOMDocumentFragment> to [exhaustively] satisfy <string>', function (expect, subject, value) {\n      var isHtml = isInsideHtmlDocument(subject);\n\n      expect.argsOutput = function (output) {\n        return output.code(value, isHtml ? 'html' : 'xml');\n      };\n\n      return expect(subject, 'to [exhaustively] satisfy', isHtml ? parseHtml(value, true) : parseXml(value));\n    });\n\n    expect.exportAssertion('<DOMDocumentFragment> to [exhaustively] satisfy <DOMDocumentFragment>', function (expect, subject, _ref3) {\n      var childNodes = _ref3.childNodes;\n\n      var isHtml = subject.ownerDocument.contentType === 'text/html';\n      return expect(subject, 'to [exhaustively] satisfy', Array.prototype.map.call(childNodes, function (childNode) {\n        return convertDOMNodeToSatisfySpec(childNode, isHtml);\n      }));\n    });\n\n    expect.exportAssertion('<DOMDocumentFragment> to [exhaustively] satisfy <object|array>', function (expect, _ref4, value) {\n      var childNodes = _ref4.childNodes;\n      return expect(childNodes, 'to [exhaustively] satisfy', value);\n    });\n\n    expect.exportAssertion('<DOMElement> to [exhaustively] satisfy <string>', function (expect, subject, value) {\n      var isHtml = isInsideHtmlDocument(subject);\n      var documentFragment = isHtml ? parseHtml(value, true) : parseXml(value);\n      if (documentFragment.childNodes.length !== 1) {\n        throw new Error('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\n      return expect(subject, 'to [exhaustively] satisfy', documentFragment.childNodes[0]);\n    });\n\n    expect.exportAssertion('<DOMDocument> to [exhaustively] satisfy <string>', function (expect, subject, value) {\n      var isHtml = isInsideHtmlDocument(subject);\n      var valueDocument = isHtml ? parseHtml(value, false) : parseXml(value);\n      return expect(makeAttachedDOMNodeList(subject.childNodes), 'to [exhaustively] satisfy', Array.prototype.map.call(valueDocument.childNodes, function (childNode) {\n        return convertDOMNodeToSatisfySpec(childNode, isHtml);\n      }));\n    });\n\n    expect.exportAssertion('<DOMDocument> to [exhaustively] satisfy <DOMDocument>', function (expect, subject, _ref5) {\n      var childNodes = _ref5.childNodes;\n\n      var isHtml = isInsideHtmlDocument(subject);\n      return expect(makeAttachedDOMNodeList(subject.childNodes), 'to [exhaustively] satisfy', Array.prototype.map.call(childNodes, function (childNode) {\n        return convertDOMNodeToSatisfySpec(childNode, isHtml);\n      }));\n    });\n\n    expect.exportAssertion('<DOMElement> to [exhaustively] satisfy <DOMElement>', function (expect, subject, value) {\n      return expect(subject, 'to [exhaustively] satisfy', convertDOMNodeToSatisfySpec(value, isInsideHtmlDocument(subject)));\n    });\n\n    expect.exportAssertion(['<DOMElement> to [exhaustively] satisfy <DOMTextNode>', '<DOMTextNode> to [exhaustively] satisfy <DOMElement>', '<DOMElement|DOMDocumentFragment|DOMDocument> to [exhaustively] satisfy <regexp>'], function (expect, subject, value) {\n      return expect.fail();\n    });\n\n    expect.exportAssertion('<DOMElement> to [exhaustively] satisfy <object>', function (expect, subject, value) {\n      var isHtml = isInsideHtmlDocument(subject);\n      var unsupportedOptions = Object.keys(value).filter(function (key) {\n        return key !== 'attributes' && key !== 'name' && key !== 'children' && key !== 'onlyAttributes' && key !== 'textContent';\n      });\n      if (unsupportedOptions.length > 0) {\n        throw new Error('Unsupported option' + (unsupportedOptions.length === 1 ? '' : 's') + ': ' + unsupportedOptions.join(', '));\n      }\n\n      var promiseByKey = {\n        name: expect.promise(function () {\n          if (value && typeof value.name !== 'undefined') {\n            return bubbleError(function () {\n              return expect(isHtml ? subject.nodeName.toLowerCase() : subject.nodeName, 'to satisfy', 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('The children and textContent properties are not supported together');\n            }\n            return bubbleError(function () {\n              return expect(makeAttachedDOMNodeList(subject.childNodes, subject.ownerDocument.contentType), 'to satisfy', value.children);\n            });\n          } else if (typeof value.textContent !== 'undefined') {\n            return bubbleError(function () {\n              return expect(subject.textContent, 'to satisfy', value.textContent);\n            });\n          }\n        }),\n        attributes: {}\n      };\n\n      var onlyAttributes = value && value.onlyAttributes || expect.flags.exhaustively;\n      var attrs = getAttributes(subject);\n      var expectedAttributes = value && value.attributes;\n      var expectedAttributeNames = [];\n      var expectedValueByAttributeName = {};\n\n      if (typeof expectedAttributes !== 'undefined') {\n        if (typeof expectedAttributes === 'string') {\n          expectedAttributes = [expectedAttributes];\n        }\n        if (Array.isArray(expectedAttributes)) {\n          expectedAttributes.forEach(function (attributeName) {\n            expectedValueByAttributeName[attributeName] = true;\n          });\n        } else if (expectedAttributes && (typeof expectedAttributes === 'undefined' ? 'undefined' : _typeof(expectedAttributes)) === 'object') {\n          expectedValueByAttributeName = expectedAttributes;\n        }\n        Object.keys(expectedValueByAttributeName).forEach(function (attributeName) {\n          expectedAttributeNames.push(attributeName);\n        });\n\n        expectedAttributeNames.forEach(function (attributeName) {\n          var attributeValue = subject.getAttribute(attributeName);\n          var expectedAttributeValue = expectedValueByAttributeName[attributeName];\n          promiseByKey.attributes[attributeName] = expect.promise(function () {\n            if (typeof expectedAttributeValue === 'undefined') {\n              return bubbleError(function () {\n                return expect(subject.hasAttribute(attributeName), 'to be false');\n              });\n            } else if (isEnumeratedAttribute(attributeName)) {\n              var indexOfEnumeratedAttributeValue = enumeratedAttributeValues[attributeName].indexOf(expectedAttributeValue);\n\n              return bubbleError(function () {\n                if (indexOfEnumeratedAttributeValue === -1) {\n                  expect.fail(function (output) {\n                    return output.text('Invalid expected value ').appendInspected(expectedAttributeValue).text('. Supported values include: ').appendItems(enumeratedAttributeValues[attributeName], ', ');\n                  });\n                }\n\n                expect(attributeValue, 'to satisfy', expectedAttributeValue);\n              });\n            } else if (expectedAttributeValue === true) {\n              return bubbleError(function () {\n                return expect(subject.hasAttribute(attributeName), 'to be true');\n              });\n            } else if (attributeName === 'class' && (typeof expectedAttributeValue === 'string' || Array.isArray(expectedAttributeValue))) {\n              var actualClasses = getClassNamesFromAttributeValue(attributeValue);\n              var expectedClasses = expectedAttributeValue;\n              if (typeof expectedClasses === 'string') {\n                expectedClasses = getClassNamesFromAttributeValue(expectedAttributeValue);\n              }\n              if (onlyAttributes) {\n                return bubbleError(function () {\n                  return expect(actualClasses.sort(), 'to equal', expectedClasses.sort());\n                });\n              } else {\n                if (expectedClasses.length === 0) {\n                  return bubbleError(function () {\n                    return expect(expectedClasses, 'to be empty');\n                  });\n                }\n                return bubbleError(function () {\n                  return expect.apply(undefined, [actualClasses, 'to contain'].concat(_toConsumableArray(expectedClasses)));\n                });\n              }\n            } else if (attributeName === 'style') {\n              var expectedStyleObj = void 0;\n              if (typeof expectedValueByAttributeName.style === 'string') {\n                validateStyles(expect, expectedValueByAttributeName.style);\n                expectedStyleObj = styleStringToObject(expectedValueByAttributeName.style);\n              } else {\n                expectedStyleObj = expectedValueByAttributeName.style;\n              }\n\n              if (onlyAttributes) {\n                return bubbleError(function () {\n                  return expect(attrs.style, 'to exhaustively satisfy', expectedStyleObj);\n                });\n              } else {\n                return bubbleError(function () {\n                  return expect(attrs.style, 'to satisfy', expectedStyleObj);\n                });\n              }\n            } else {\n              return bubbleError(function () {\n                return expect(attributeValue, 'to satisfy', expectedAttributeValue);\n              });\n            }\n          });\n        });\n\n        promiseByKey.attributePresence = expect.promise(function () {\n          var attributeNamesExpectedToBeDefined = [];\n          expectedAttributeNames.forEach(function (attributeName) {\n            if (typeof expectedValueByAttributeName[attributeName] === 'undefined') {\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(Object.keys(attrs).sort(), 'to equal', attributeNamesExpectedToBeDefined.sort());\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 diff(output, _diff7, inspect, equal) {\n              output.block(function (output) {\n                var seenError = false;\n                output.prismPunctuation('<').prismTag(isHtml ? subject.nodeName.toLowerCase() : subject.nodeName);\n                if (promiseByKey.name.isRejected()) {\n                  seenError = true;\n                  var nameError = promiseByKey.name.reason();\n                  output.sp().annotationBlock(function (output) {\n                    return output.error(nameError && nameError.getLabel() || 'should satisfy').sp().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(attributeOutput, attributeName, attrs[attributeName], isHtml);\n                  if (promise && promise.isFulfilled() || !promise && (!onlyAttributes || expectedAttributeNames.indexOf(attributeName) !== -1)) {} else {\n                    seenError = true;\n                    attributeOutput.sp().annotationBlock(function (output) {\n                      if (promise && typeof expectedValueByAttributeName[attributeName] !== 'undefined') {\n                        output.appendErrorMessage(promise.reason());\n                      } else {\n                        // onlyAttributes === true\n                        output.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.clone().annotationBlock(function (output) {\n                        output.error('missing').sp().prismAttrName(attributeName, 'html');\n                        if (expectedValueByAttributeName[attributeName] !== true) {\n                          output.sp().error(err && err.getLabel() || 'should satisfy').sp().append(inspect(expectedValueByAttributeName[attributeName]));\n                        }\n                      });\n                      inspectedAttributes.push(attributeOutput);\n                    }\n                  }\n                });\n                if (inspectedAttributes.length > 0) {\n                  if (seenError) {\n                    output.nl().indentLines().indent().block(function (output) {\n                      inspectedAttributes.forEach(function (item, i) {\n                        if (i > 0) {\n                          output.nl();\n                        }\n                        output.append(item);\n                      });\n                    }).outdentLines().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 = promiseByKey.children.isRejected() && promiseByKey.children.reason();\n                if (childrenError) {\n                  var childrenDiff = childrenError.getDiff(output);\n                  if (childrenDiff && childrenDiff.inline) {\n                    output.nl().indentLines().i().block(childrenDiff.diff).nl().outdentLines();\n                  } else {\n                    output.nl().indentLines().i().block(function (output) {\n                      for (var i = 0; i < subject.childNodes.length; i += 1) {\n                        output.append(inspect(subject.childNodes[i])).nl();\n                      }\n                    });\n                    output.sp().annotationBlock(function (output) {\n                      return output.appendErrorMessage(childrenError);\n                    });\n                    output.nl();\n                  }\n                } else {\n                  for (var i = 0; i < subject.childNodes.length; i += 1) {\n                    output.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    expect.exportAssertion('<DOMElement> to [only] have (attribute|attributes) <string+>', function (expect, subject) {\n      for (var _len = arguments.length, args = Array(_len > 2 ? _len - 2 : 0), _key = 2; _key < _len; _key++) {\n        args[_key - 2] = arguments[_key];\n      }\n\n      return expect(subject, 'to [only] have attributes', args);\n    });\n\n    expect.exportAssertion('<DOMElement> not to have (attribute|attributes) <array>', 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    expect.exportAssertion('<DOMElement> not to have (attribute|attributes) <string+>', function (expect, subject) {\n      for (var _len2 = arguments.length, args = Array(_len2 > 2 ? _len2 - 2 : 0), _key2 = 2; _key2 < _len2; _key2++) {\n        args[_key2 - 2] = arguments[_key2];\n      }\n\n      return expect(subject, 'not to have attributes', args);\n    });\n\n    expect.exportAssertion('<DOMElement> to [only] have (attribute|attributes) <array|object>', function (expect, subject, value) {\n      return expect(subject, 'to satisfy', {\n        attributes: value,\n        onlyAttributes: expect.flags.only\n      });\n    });\n\n    expect.exportAssertion('<DOMElement> to have [no] (child|children)', function (expect, _ref6) {\n      var childNodes = _ref6.childNodes;\n      return expect.flags.no ? expect(childNodes, 'to be empty') : expect(childNodes, 'not to be empty');\n    });\n\n    expect.exportAssertion('<DOMElement> to have text <any>', function (expect, _ref7, value) {\n      var textContent = _ref7.textContent;\n      return expect(textContent, 'to satisfy', value);\n    });\n\n    expect.exportAssertion('<DOMDocument|DOMElement|DOMDocumentFragment> [when] queried for [first] <string> <assertion?>', function (expect, subject, query) {\n      var queryResult = void 0;\n\n      expect.argsOutput[0] = function (output) {\n        return output.green(query);\n      };\n      expect.errorMode = 'nested';\n\n      if (expect.flags.first) {\n        queryResult = subject.querySelector(query);\n        if (!queryResult) {\n          expect.subjectOutput = function (output) {\n            return expect.inspect(subject, Infinity, output);\n          };\n\n          expect.fail(function (output) {\n            return output.error('The selector').sp().jsString(query).sp().error('yielded no results');\n          });\n        }\n      } else {\n        queryResult = subject.querySelectorAll(query);\n        if (queryResult.length === 0) {\n          expect.subjectOutput = function (output) {\n            return expect.inspect(subject, Infinity, output);\n          };\n\n          expect.fail(function (output) {\n            return output.error('The selector').sp().jsString(query).sp().error('yielded no results');\n          });\n        }\n      }\n      return expect.shift(queryResult);\n    });\n\n    expect.exportAssertion('<DOMDocument|DOMElement|DOMDocumentFragment> to contain [no] elements matching <string>', 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        return expect.inspect(subject, Infinity, output);\n      };\n\n      return expect(subject.querySelectorAll(query), 'not to satisfy', []);\n    });\n\n    expect.exportAssertion('<DOMDocument|DOMElement|DOMDocumentFragment> [not] to match <string>', function (expect, subject, query) {\n      expect.subjectOutput = function (output) {\n        return expect.inspect(subject, Infinity, output);\n      };\n\n      return expect(matchesSelector(subject, query), '[not] to be true');\n    });\n\n    expect.exportAssertion('<string> [when] parsed as (html|HTML) [fragment] <assertion?>', function (expect, subject) {\n      expect.errorMode = 'nested';\n      return expect.shift(parseHtml(subject, expect.flags.fragment));\n    });\n\n    expect.exportAssertion('<string> [when] parsed as (xml|XML) <assertion?>', function (expect, subject) {\n      expect.errorMode = 'nested';\n      return expect.shift(parseXml(subject));\n    });\n  }\n};","\"use strict\";\n\nmodule.exports = function (elm, selector) {\n  var matchFuntion = elm.matchesSelector || elm.mozMatchesSelector || elm.msMatchesSelector || elm.oMatchesSelector || elm.webkitMatchesSelector || 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};","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    \"/unexpected-markdown\"\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 7cc6ee10..4602140c 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 r(e,n,t){function o(i,f){if(!n[i]){if(!e[i]){var c="function"==typeof require&&require;if(!f&&c)return c(i,!0);if(u)return u(i,!0);var a=new Error("Cannot find module '"+i+"'");throw a.code="MODULE_NOT_FOUND",a}var p=n[i]={exports:{}};e[i][0].call(p.exports,function(r){var n=e[i][1][r];return o(n||r)},p,p.exports,r,e,n,t)}return n[i].exports}for(var u="function"==typeof require&&require,i=0;i"}var htmlDocument=getHtmlDocument(str);if(isFragment){var body=htmlDocument.body;var documentFragment=htmlDocument.createDocumentFragment();if(body){for(var i=0;i0){expect.errorMode="nested";expect.fail("Expectation contains invalid styles: {0}",invalidStyles.join(";"))}}function styleStringToObject(str){var styles={};str.split(";").forEach(function(rule){var tuple=rule.split(":").map(function(part){return part.trim()});if(tuple[0]&&tuple[1]){styles[tuple[0]]=tuple[1]}});return styles}function getClassNamesFromAttributeValue(attributeValue){if(attributeValue===null){return[]}if(attributeValue===""){return[]}var classNames=attributeValue.split(/\s+/);if(classNames.length===1&&classNames[0]===""){classNames.pop()}return classNames}function isInsideHtmlDocument(node){var ownerDocument=node.nodeType===9&&node.documentElement&&node.implementation?node:node.ownerDocument;if(ownerDocument.contentType){return ownerDocument.contentType==="text/html"}else{return ownerDocument.toString()==="[object HTMLDocument]"}}function getAttributes(element){var isHtml=isInsideHtmlDocument(element);var attrs=element.attributes;var result={};for(var i=0;i"}}module.exports={name:"unexpected-dom",installInto:function installInto(expect){expect=expect.child();expect.use(require("magicpen-prism"));function bubbleError(body){return expect.withError(body,function(err){err.errorMode="bubble";throw err})}expect.exportType({name:"DOMNode",base:"object",identify:function identify(obj){return obj&&obj.nodeName&&[2,3,4,5,6,7,10,11,12].indexOf(obj.nodeType)>-1},equal:function equal(a,b){return a.nodeValue===b.nodeValue},inspect:function inspect(element,depth,output){return output.code(element.nodeName+' "'+element.nodeValue+'"',"prism-string")}});expect.exportType({name:"DOMComment",base:"DOMNode",identify:function identify(obj){return obj&&typeof obj.nodeType==="number"&&obj.nodeType===8},equal:function equal(a,b){return a.nodeValue===b.nodeValue},inspect:function inspect(element,depth,output){return output.code("\x3c!--"+element.nodeValue+"--\x3e","html")},diff:function diff(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:"DOMIgnoreComment",base:"DOMComment",identify:function identify(obj){return this.baseType.identify(obj)&&/^\s*ignore\s*$/.test(obj.nodeValue)}});expect.exportType({name:"DOMTextNode",base:"DOMNode",identify:function identify(obj){return obj&&typeof obj.nodeType==="number"&&obj.nodeType===3},equal:function equal(a,b){return a.nodeValue===b.nodeValue},inspect:function inspect(element,depth,output){return output.code(entitify(element.nodeValue.trim()),"html")},diff:function diff(actual,expected,output,_diff2,inspect,equal){var d=_diff2(actual.nodeValue,expected.nodeValue);d.inline=true;return d}});expect.exportType({name:"DOMNodeList",base:"array-like",prefix:function prefix(output){return output.text("NodeList[")},suffix:function suffix(output){return output.text("]")},similar:function similar(a,b){return a.nodeType===1&&b.nodeType===1&&a.nodeName===b.nodeName},identify:function identify(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 prefix(output){return output},suffix:function suffix(output){return output},delimiter:function delimiter(output){return output},identify:function identify(obj){return obj&&obj._isAttachedDOMNodeList}});function makeAttachedDOMNodeList(domNodeList,contentType){var attachedDOMNodeList=[];for(var i=0;i","html")},equal:function equal(a,b){return a.toString()===b.toString()},diff:function diff(actual,expected,output,_diff3){var d=_diff3("","");d.inline=true;return d}});expect.exportType({name:"DOMDocument",base:"DOMNode",identify:function identify(obj){return obj&&typeof obj.nodeType==="number"&&obj.nodeType===9&&obj.documentElement&&obj.implementation},inspect:function inspect(document,depth,output,_inspect2){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){return output.append(inspectedChild)})}}}output.code(stringifyEndTag(element),"html");return output},diffLimit:512,diff:function diff(actual,expected,output,_diff6,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(output){return output.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(output){return output.error("should equal").sp().append(inspect(entitify(expectedAttributes[attributeName])))}).nl();canContinueLine=false}delete expectedAttributes[attributeName]}else{output.sp().annotationBlock(function(output){return output.error("should be removed")}).nl();canContinueLine=false}});Object.keys(expectedAttributes).forEach(function(attributeName){output.sp(canContinueLine?1:2+actual.nodeName.length);output.annotationBlock(function(output){output.error("missing").sp();writeAttributeToMagicPen(output,attributeName,expectedAttributes[attributeName],isHtml)}).nl();canContinueLine=false});output.prismPunctuation(">")}else{output.code(stringifyStartTag(actual),"html")}if(!emptyElements){output.nl().indentLines().i().block(_diff6(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 _class(className){var actualClasses=getClassNamesFromAttributeValue(className);if(typeof value==="string"){value=getClassNamesFromAttributeValue(value)}return bubbleError(function(){return expect(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){return expect(subject.nodeValue,"to equal",value.nodeValue)});expect.exportAssertion(" to [exhaustively] satisfy ",function(expect,subject,value){return expect.fail()});expect.exportAssertion(" to [exhaustively] satisfy ",function(expect,subject,value){});expect.exportAssertion(" to [exhaustively] satisfy ",function(expect,_ref,value){var nodeValue=_ref.nodeValue;return expect(nodeValue,"to satisfy",value)});expect.exportAssertion(" to [exhaustively] satisfy ",function(expect,_ref2,value){var nodeValue=_ref2.nodeValue;return expect(nodeValue,"to satisfy",value)});function convertDOMNodeToSatisfySpec(node,isHtml){if(node.nodeType===10){return{name:node.nodeName}}else if(node.nodeType===1){var name=isHtml?node.nodeName.toLowerCase():node.nodeName;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):parseXml(value)).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):parseXml(value))});expect.exportAssertion(" to [exhaustively] satisfy ",function(expect,subject,_ref3){var childNodes=_ref3.childNodes;var isHtml=subject.ownerDocument.contentType==="text/html";return expect(subject,"to [exhaustively] satisfy",Array.prototype.map.call(childNodes,function(childNode){return convertDOMNodeToSatisfySpec(childNode,isHtml)}))});expect.exportAssertion(" to [exhaustively] satisfy ",function(expect,_ref4,value){var childNodes=_ref4.childNodes;return expect(childNodes,"to [exhaustively] satisfy",value)});expect.exportAssertion(" to [exhaustively] satisfy ",function(expect,subject,value){var isHtml=isInsideHtmlDocument(subject);var documentFragment=isHtml?parseHtml(value,true):parseXml(value);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):parseXml(value);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,_ref5){var childNodes=_ref5.childNodes;var isHtml=isInsideHtmlDocument(subject);return expect(makeAttachedDOMNodeList(subject.childNodes),"to [exhaustively] satisfy",Array.prototype.map.call(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 "," to [exhaustively] satisfy "," to [exhaustively] satisfy "],function(expect,subject,value){return 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 bubbleError(function(){return expect(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 bubbleError(function(){return expect(makeAttachedDOMNodeList(subject.childNodes,subject.ownerDocument.contentType),"to satisfy",value.children)})}else if(typeof value.textContent!=="undefined"){return bubbleError(function(){return expect(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=[];var expectedValueByAttributeName={};if(typeof expectedAttributes!=="undefined"){if(typeof expectedAttributes==="string"){expectedAttributes=[expectedAttributes]}if(Array.isArray(expectedAttributes)){expectedAttributes.forEach(function(attributeName){expectedValueByAttributeName[attributeName]=true})}else if(expectedAttributes&&(typeof expectedAttributes==="undefined"?"undefined":_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(typeof expectedAttributeValue==="undefined"){return bubbleError(function(){return expect(subject.hasAttribute(attributeName),"to be false")})}else if(isEnumeratedAttribute(attributeName)){var indexOfEnumeratedAttributeValue=enumeratedAttributeValues[attributeName].indexOf(expectedAttributeValue);return bubbleError(function(){if(indexOfEnumeratedAttributeValue===-1){expect.fail(function(output){return output.text("Invalid expected value ").appendInspected(expectedAttributeValue).text(". Supported values include: ").appendItems(enumeratedAttributeValues[attributeName],", ")})}expect(attributeValue,"to satisfy",expectedAttributeValue)})}else if(expectedAttributeValue===true){return bubbleError(function(){return expect(subject.hasAttribute(attributeName),"to be true")})}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 bubbleError(function(){return expect(actualClasses.sort(),"to equal",expectedClasses.sort())})}else{if(expectedClasses.length===0){return bubbleError(function(){return expect(expectedClasses,"to be empty")})}return bubbleError(function(){return expect.apply(undefined,[actualClasses,"to contain"].concat(_toConsumableArray(expectedClasses)))})}}else if(attributeName==="style"){var expectedStyleObj=void 0;if(typeof expectedValueByAttributeName.style==="string"){validateStyles(expect,expectedValueByAttributeName.style);expectedStyleObj=styleStringToObject(expectedValueByAttributeName.style)}else{expectedStyleObj=expectedValueByAttributeName.style}if(onlyAttributes){return bubbleError(function(){return expect(attrs.style,"to exhaustively satisfy",expectedStyleObj)})}else{return bubbleError(function(){return expect(attrs.style,"to satisfy",expectedStyleObj)})}}else{return bubbleError(function(){return expect(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 diff(output,_diff7,inspect,equal){output.block(function(output){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(output){return output.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(output){if(promise&&typeof expectedValueByAttributeName[attributeName]!=="undefined"){output.appendErrorMessage(promise.reason())}else{output.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(output){output.error("missing").sp().prismAttrName(attributeName,"html");if(expectedValueByAttributeName[attributeName]!==true){output.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){output.nl().indentLines().i().block(childrenDiff.diff).nl().outdentLines()}else{output.nl().indentLines().i().block(function(output){for(var i=0;i to [only] have (attribute|attributes) ",function(expect,subject){for(var _len=arguments.length,args=Array(_len>2?_len-2:0),_key=2;_key<_len;_key++){args[_key-2]=arguments[_key]}return expect(subject,"to [only] have attributes",args)});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){for(var _len2=arguments.length,args=Array(_len2>2?_len2-2:0),_key2=2;_key2<_len2;_key2++){args[_key2-2]=arguments[_key2]}return expect(subject,"not to have attributes",args)});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,_ref6){var childNodes=_ref6.childNodes;return expect.flags.no?expect(childNodes,"to be empty"):expect(childNodes,"not to be empty")});expect.exportAssertion(" to have text ",function(expect,_ref7,value){var textContent=_ref7.textContent;return expect(textContent,"to satisfy",value)});expect.exportAssertion(" [when] queried for [first] ",function(expect,subject,query){var queryResult=void 0;expect.argsOutput[0]=function(output){return output.green(query)};expect.errorMode="nested";if(expect.flags.first){queryResult=subject.querySelector(query);if(!queryResult){expect.subjectOutput=function(output){return expect.inspect(subject,Infinity,output)};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.subjectOutput=function(output){return expect.inspect(subject,Infinity,output)};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){return expect.inspect(subject,Infinity,output)};return expect(subject.querySelectorAll(query),"not to satisfy",[])});expect.exportAssertion(" [not] to match ",function(expect,subject,query){expect.subjectOutput=function(output){return expect.inspect(subject,Infinity,output)};return expect(matchesSelector(subject,query),"[not] to be true")}) +(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 r(e,n,t){function o(i,f){if(!n[i]){if(!e[i]){var c="function"==typeof require&&require;if(!f&&c)return c(i,!0);if(u)return u(i,!0);var a=new Error("Cannot find module '"+i+"'");throw a.code="MODULE_NOT_FOUND",a}var p=n[i]={exports:{}};e[i][0].call(p.exports,function(r){var n=e[i][1][r];return o(n||r)},p,p.exports,r,e,n,t)}return n[i].exports}for(var u="function"==typeof require&&require,i=0;i"}var htmlDocument=getHtmlDocument(str);if(isFragment){var body=htmlDocument.body;var documentFragment=htmlDocument.createDocumentFragment();if(body){for(var i=0;i0){expect.errorMode="nested";expect.fail("Expectation contains invalid styles: {0}",invalidStyles.join(";"))}}function styleStringToObject(str){var styles={};str.split(";").forEach(function(rule){var tuple=rule.split(":").map(function(part){return part.trim()});if(tuple[0]&&tuple[1]){styles[tuple[0]]=tuple[1]}});return styles}function getClassNamesFromAttributeValue(attributeValue){if(attributeValue===null){return[]}if(attributeValue===""){return[]}var classNames=attributeValue.split(/\s+/);if(classNames.length===1&&classNames[0]===""){classNames.pop()}return classNames}function isInsideHtmlDocument(node){var ownerDocument=node.nodeType===9&&node.documentElement&&node.implementation?node:node.ownerDocument;if(ownerDocument.contentType){return ownerDocument.contentType==="text/html"}else{return ownerDocument.toString()==="[object HTMLDocument]"}}function getAttributes(element){var isHtml=isInsideHtmlDocument(element);var attrs=element.attributes;var result={};for(var i=0;i"}}module.exports={name:"unexpected-dom",installInto:function installInto(expect){expect=expect.child();expect.use(require("magicpen-prism"));function bubbleError(body){return expect.withError(body,function(err){err.errorMode="bubble";throw err})}expect.exportType({name:"DOMNode",base:"object",identify:function identify(obj){return obj&&obj.nodeName&&[2,3,4,5,6,7,10,11,12].indexOf(obj.nodeType)>-1},equal:function equal(a,b){return a.nodeValue===b.nodeValue},inspect:function inspect(element,depth,output){return output.code(element.nodeName+' "'+element.nodeValue+'"',"prism-string")}});expect.exportType({name:"DOMComment",base:"DOMNode",identify:function identify(obj){return obj&&typeof obj.nodeType==="number"&&obj.nodeType===8},equal:function equal(a,b){return a.nodeValue===b.nodeValue},inspect:function inspect(element,depth,output){return output.code("\x3c!--"+element.nodeValue+"--\x3e","html")},diff:function diff(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:"DOMIgnoreComment",base:"DOMComment",identify:function identify(obj){return this.baseType.identify(obj)&&/^\s*ignore\s*$/.test(obj.nodeValue)}});expect.exportType({name:"DOMTextNode",base:"DOMNode",identify:function identify(obj){return obj&&typeof obj.nodeType==="number"&&obj.nodeType===3},equal:function equal(a,b){return a.nodeValue===b.nodeValue},inspect:function inspect(element,depth,output){return output.code(entitify(element.nodeValue.trim()),"html")},diff:function diff(actual,expected,output,_diff2,inspect,equal){var d=_diff2(actual.nodeValue,expected.nodeValue);d.inline=true;return d}});expect.exportType({name:"DOMNodeList",base:"array-like",prefix:function prefix(output){return output.text("NodeList[")},suffix:function suffix(output){return output.text("]")},similar:function similar(a,b){return a.nodeType===1&&b.nodeType===1&&a.nodeName===b.nodeName},identify:function identify(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 prefix(output){return output},suffix:function suffix(output){return output},delimiter:function delimiter(output){return output},identify:function identify(obj){return obj&&obj._isAttachedDOMNodeList}});function makeAttachedDOMNodeList(domNodeList,contentType){var attachedDOMNodeList=[];for(var i=0;i","html")},equal:function equal(a,b){return a.toString()===b.toString()},diff:function diff(actual,expected,output,_diff3){var d=_diff3("","");d.inline=true;return d}});expect.exportType({name:"DOMDocument",base:"DOMNode",identify:function identify(obj){return obj&&typeof obj.nodeType==="number"&&obj.nodeType===9&&obj.documentElement&&obj.implementation},inspect:function inspect(document,depth,output,_inspect2){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){return output.append(inspectedChild)})}}}output.code(stringifyEndTag(element),"html");return output},diffLimit:512,diff:function diff(actual,expected,output,_diff6,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(output){return output.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(output){return output.error("should equal").sp().append(inspect(entitify(expectedAttributes[attributeName])))}).nl();canContinueLine=false}delete expectedAttributes[attributeName]}else{output.sp().annotationBlock(function(output){return output.error("should be removed")}).nl();canContinueLine=false}});Object.keys(expectedAttributes).forEach(function(attributeName){output.sp(canContinueLine?1:2+actual.nodeName.length);output.annotationBlock(function(output){output.error("missing").sp();writeAttributeToMagicPen(output,attributeName,expectedAttributes[attributeName],isHtml)}).nl();canContinueLine=false});output.prismPunctuation(">")}else{output.code(stringifyStartTag(actual),"html")}if(!emptyElements){output.nl().indentLines().i().block(_diff6(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 _class(className){var actualClasses=getClassNamesFromAttributeValue(className);if(typeof value==="string"){value=getClassNamesFromAttributeValue(value)}return bubbleError(function(){return expect(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){return expect(subject.nodeValue,"to equal",value.nodeValue)});expect.exportAssertion(" to [exhaustively] satisfy ",function(expect,subject,value){return expect.fail()});expect.exportAssertion(" to [exhaustively] satisfy ",function(expect,subject,value){});expect.exportAssertion(" to [exhaustively] satisfy ",function(expect,_ref,value){var nodeValue=_ref.nodeValue;return expect(nodeValue,"to satisfy",value)});expect.exportAssertion(" to [exhaustively] satisfy ",function(expect,_ref2,value){var nodeValue=_ref2.nodeValue;return expect(nodeValue,"to satisfy",value)});function convertDOMNodeToSatisfySpec(node,isHtml){if(node.nodeType===10){return{name:node.nodeName}}else if(node.nodeType===1){var name=isHtml?node.nodeName.toLowerCase():node.nodeName;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):parseXml(value)).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):parseXml(value))});expect.exportAssertion(" to [exhaustively] satisfy ",function(expect,subject,_ref3){var childNodes=_ref3.childNodes;var isHtml=subject.ownerDocument.contentType==="text/html";return expect(subject,"to [exhaustively] satisfy",Array.prototype.map.call(childNodes,function(childNode){return convertDOMNodeToSatisfySpec(childNode,isHtml)}))});expect.exportAssertion(" to [exhaustively] satisfy ",function(expect,_ref4,value){var childNodes=_ref4.childNodes;return expect(childNodes,"to [exhaustively] satisfy",value)});expect.exportAssertion(" to [exhaustively] satisfy ",function(expect,subject,value){var isHtml=isInsideHtmlDocument(subject);var documentFragment=isHtml?parseHtml(value,true):parseXml(value);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):parseXml(value);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,_ref5){var childNodes=_ref5.childNodes;var isHtml=isInsideHtmlDocument(subject);return expect(makeAttachedDOMNodeList(subject.childNodes),"to [exhaustively] satisfy",Array.prototype.map.call(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 "," to [exhaustively] satisfy "," to [exhaustively] satisfy "],function(expect,subject,value){return 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 bubbleError(function(){return expect(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 bubbleError(function(){return expect(makeAttachedDOMNodeList(subject.childNodes,subject.ownerDocument.contentType),"to satisfy",value.children)})}else if(typeof value.textContent!=="undefined"){return bubbleError(function(){return expect(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=[];var expectedValueByAttributeName={};if(typeof expectedAttributes!=="undefined"){if(typeof expectedAttributes==="string"){expectedAttributes=[expectedAttributes]}if(Array.isArray(expectedAttributes)){expectedAttributes.forEach(function(attributeName){expectedValueByAttributeName[attributeName]=true})}else if(expectedAttributes&&(typeof expectedAttributes==="undefined"?"undefined":_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(typeof expectedAttributeValue==="undefined"){return bubbleError(function(){return expect(subject.hasAttribute(attributeName),"to be false")})}else if(isEnumeratedAttribute(attributeName)){var indexOfEnumeratedAttributeValue=enumeratedAttributeValues[attributeName].indexOf(expectedAttributeValue);return bubbleError(function(){if(indexOfEnumeratedAttributeValue===-1){expect.fail(function(output){return output.text("Invalid expected value ").appendInspected(expectedAttributeValue).text(". Supported values include: ").appendItems(enumeratedAttributeValues[attributeName],", ")})}expect(attributeValue,"to satisfy",expectedAttributeValue)})}else if(expectedAttributeValue===true){return bubbleError(function(){return expect(subject.hasAttribute(attributeName),"to be true")})}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 bubbleError(function(){return expect(actualClasses.sort(),"to equal",expectedClasses.sort())})}else{if(expectedClasses.length===0){return bubbleError(function(){return expect(expectedClasses,"to be empty")})}return bubbleError(function(){return expect.apply(undefined,[actualClasses,"to contain"].concat(_toConsumableArray(expectedClasses)))})}}else if(attributeName==="style"){var expectedStyleObj=void 0;if(typeof expectedValueByAttributeName.style==="string"){validateStyles(expect,expectedValueByAttributeName.style);expectedStyleObj=styleStringToObject(expectedValueByAttributeName.style)}else{expectedStyleObj=expectedValueByAttributeName.style}if(onlyAttributes){return bubbleError(function(){return expect(attrs.style,"to exhaustively satisfy",expectedStyleObj)})}else{return bubbleError(function(){return expect(attrs.style,"to satisfy",expectedStyleObj)})}}else{return bubbleError(function(){return expect(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 diff(output,_diff7,inspect,equal){output.block(function(output){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(output){return output.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(output){if(promise&&typeof expectedValueByAttributeName[attributeName]!=="undefined"){output.appendErrorMessage(promise.reason())}else{output.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(output){output.error("missing").sp().prismAttrName(attributeName,"html");if(expectedValueByAttributeName[attributeName]!==true){output.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){output.nl().indentLines().i().block(childrenDiff.diff).nl().outdentLines()}else{output.nl().indentLines().i().block(function(output){for(var i=0;i to [only] have (attribute|attributes) ",function(expect,subject){for(var _len=arguments.length,args=Array(_len>2?_len-2:0),_key=2;_key<_len;_key++){args[_key-2]=arguments[_key]}return expect(subject,"to [only] have attributes",args)});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){for(var _len2=arguments.length,args=Array(_len2>2?_len2-2:0),_key2=2;_key2<_len2;_key2++){args[_key2-2]=arguments[_key2]}return expect(subject,"not to have attributes",args)});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,_ref6){var childNodes=_ref6.childNodes;return expect.flags.no?expect(childNodes,"to be empty"):expect(childNodes,"not to be empty")});expect.exportAssertion(" to have text ",function(expect,_ref7,value){var textContent=_ref7.textContent;return expect(textContent,"to satisfy",value)});expect.exportAssertion(" [when] queried for [first] ",function(expect,subject,query){var queryResult=void 0;expect.argsOutput[0]=function(output){return output.green(query)};expect.errorMode="nested";if(expect.flags.first){queryResult=subject.querySelector(query);if(!queryResult){expect.subjectOutput=function(output){return expect.inspect(subject,Infinity,output)};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.subjectOutput=function(output){return expect.inspect(subject,Infinity,output)};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){return expect.inspect(subject,Infinity,output)};return expect(subject.querySelectorAll(query),"not to satisfy",[])});expect.exportAssertion(" [not] to match ",function(expect,subject,query){expect.subjectOutput=function(output){return expect.inspect(subject,Infinity,output)};return expect(matchesSelector(subject,query),"[not] to be true")}) ;expect.exportAssertion(" [when] parsed as (html|HTML) [fragment] ",function(expect,subject){expect.errorMode="nested";return expect.shift(parseHtml(subject,expect.flags.fragment))});expect.exportAssertion(" [when] parsed as (xml|XML) ",function(expect,subject){expect.errorMode="nested";return expect.shift(parseXml(subject))})}}},{"./matchesSelector":2,"magicpen-prism":3}],2:[function(require,module,exports){"use strict";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:["/","/unexpected-markdown"],_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)});